IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

VB.NET Discussion :

Problème de champ vide dans une base sql


Sujet :

VB.NET

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    162
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2008
    Messages : 162
    Points : 49
    Points
    49
    Par défaut Problème de champ vide dans une base sql
    Bonjour, j'ai fais un programme qui fais appel à une base de données et ensuite je l'affiche dans un "GridView" et sur une page "Html".
    Cette base de données contient des adresses et d'autres informations mais certains de ces champs sont vident.

    J'avais un problème avec les accents
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (lecteur("ADRESSE").ToString()).Replace("'", "''")
    Mais les champs vident je ne trouve pas ce que je pourrais mettre et il m'affiche une erreur, celle là évidement et il plante mon programme.

    J'espere avoir été clair merci d'avance.

  2. #2
    Membre actif
    Profil pro
    Inscrit en
    Février 2008
    Messages
    229
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2008
    Messages : 229
    Points : 219
    Points
    219
    Par défaut
    les champs blanc dans ta bdd te provoque des erreur dans ton datagrid?

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    162
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2008
    Messages : 162
    Points : 49
    Points
    49
    Par défaut
    oui, enfin c'est même pas des erreurs il plante avant d'afficher quelque chose.

  4. #4
    Membre actif
    Profil pro
    Inscrit en
    Février 2008
    Messages
    229
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2008
    Messages : 229
    Points : 219
    Points
    219
    Par défaut
    mais p-e des points d'arrêt pour savoir a quoi s'en tenir

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    162
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2008
    Messages : 162
    Points : 49
    Points
    49
    Par défaut
    Non cela vient de là car lorsque je remplis mes champs vident il ne plante pas.

  6. #6
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 173
    Points : 25 113
    Points
    25 113
    Par défaut
    une valeur null dans la base se traduit par un dbnull en vb
    il faut donc tester si la valeur est null avant de faire tostring, car tostring sur null ca plante

    ou alors dans ta requete ou tu remontes l'adresse, remonte ISNULL(adresse,'') as adresse
    comme ca les null remonteront en chaine vide

  7. #7
    Membre actif
    Profil pro
    Inscrit en
    Février 2008
    Messages
    229
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Février 2008
    Messages : 229
    Points : 219
    Points
    219
    Par défaut
    si tu remplis tes cases vides par une case avec des espaces??

  8. #8
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    162
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2008
    Messages : 162
    Points : 49
    Points
    49
    Par défaut
    Oui c'est exactement l'erreur qu'il m'affiche.
    Mais je n'ai pas compris ta solution?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    (lecteur("ADRESSE").ToString()).Replace("'", "''")
    Je fais comment pour tester mon adresse avant ceci?

    Et si je le remplace par des espaces cela fonctionne mais il y a 630 lignes donc faudrait un truc qui me le remplace?

  9. #9
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 173
    Points : 25 113
    Points
    25 113
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if lecteur("ADRESSE") is system.dbnull.value then

  10. #10
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    162
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2008
    Messages : 162
    Points : 49
    Points
    49
    Par défaut
    Je ne sais pas mettre de "if" dans ma requête "insert"

  11. #11
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    162
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2008
    Messages : 162
    Points : 49
    Points
    49
    Par défaut
    Ma requête ressemble à ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Dim vReq2 As String = "INSERT INTO ESSAI1(Adresse,Title,Description,) VALUES ('" & (lecteur("ADRESSE").ToString()).Replace("'", "''") & "','" & (lecteur("NOM").ToString()) & "','" & "Nom : " & "'+'" & (lecteur("NOM").ToString()) & "'+'" & (lecteur("SAUT").ToString()) & "'+'" & "Adresse : " & "'+'" & (lecteur("ADRESSE").ToString()).Replace("'", "''") & "'+'" & (lecteur("SAUT").ToString()) & "'+'" & vbCrLf & "'+'" & "Activite : " & "'+'" & (lecteur("id_activite").ToString()) & "'+'" & (lecteur("SAUT").ToString()) & "'+'" & vbCrLf & "'+'" & "Téléphone : " & "'+'" & (lecteur("TELEPHONE").ToString()) & "'.....

  12. #12
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 173
    Points : 25 113
    Points
    25 113
    Par défaut
    on parle pas de la meme chose en fait
    donc je comprends pas ce que t'essais de faire
    c'est quoi "lecteur" ?

    sinon à la place des (style des années 80) il y a les sqlparameter
    ce qui permet un code plus lisible, une requete plus sur, et ca evite les désagrément de faille de sécurité

    parce que là ta requete est pas lisible et semble comporter quelques erreurs de syntaxe

  13. #13
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    162
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2008
    Messages : 162
    Points : 49
    Points
    49
    Par défaut
    J'en utilise déja des "sql parameter" mais lorsque mon champ est vide cela plante quand même et sinon le "lecteur" me permet de lire mes informations contenues dans les "textbox".
    Et oui c'est surement vieux mais cela fonctionne tres bien. Et j'ai des valeur "null" dans d'autres champ c'est pour ça que je me suis dit que avec ".replace" il y a moyen de faire quelque chose

  14. #14
    Rédacteur
    Avatar de SaumonAgile
    Homme Profil pro
    Team leader
    Inscrit en
    Avril 2007
    Messages
    4 028
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Team leader
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2007
    Messages : 4 028
    Points : 6 334
    Points
    6 334
    Par défaut
    Citation Envoyé par lionel256 Voir le message
    c'est surement vieux mais cela fonctionne tres bien.
    Je crois que tu confons l'expression "fonctionne très bien" avec l'expression "ne plante pas trop souvent". Si les paramètres SQL existent, c'est pour (entre autres) se débarasser de ce genre de pratiques archaiques.
    Ensuite, si tu choisis de ne pas les utiliser, tu t'exposes volontairement à tout un tas de problèmes.

    Pour en revenir à ton problème, si tu ne veux pas mettre à jour ton champ, pourquoi le mentionner dans la requête ?

Discussions similaires

  1. [Oracle] Ignorer les champs vides dans une requête sql
    Par roswina dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 26/05/2015, 09h29
  2. Réponses: 4
    Dernier message: 19/07/2010, 23h43
  3. problème d'insertion dans une base SQL Server 2000 Via un trigger
    Par Alexandre_g dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 05/04/2009, 15h30
  4. Insérer des champs vides dans une requête sql
    Par js8bleu dans le forum Langage SQL
    Réponses: 4
    Dernier message: 19/02/2008, 15h00
  5. Réponses: 5
    Dernier message: 10/05/2006, 15h47

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo