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

Requêtes et SQL. Discussion :

Probleme avec Requete Update


Sujet :

Requêtes et SQL.

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    144
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 144
    Points : 54
    Points
    54
    Par défaut Probleme avec Requete Update
    Bonjour,
    Alors j'ai une table Data2 et je veux
    donner la valeur du champ STREET_1
    au champ HOUSE_NO_1
    quand la fonction IsNumerique = 1

    Requete:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    UPDATE Data2 
    SET HOUSE_NO_1 = STREET_1
    WHERE IsNumerique(STREET_1) = 1;

    Fonction:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    Function IsNumerique(ByVal Prefix As String) As Integer
     
    If ((Asc(Prefix) >= 48) And (Asc(Prefix) <= 57)) Then
     
    IsNumerique = 1
     
    Else
     
    IsNumerique = 0
    End If
     
    End Function

    J'ai une erreur type mismatch lors de l'execution de la requete
    si quelqu'un a une idée

  2. #2
    Responsable Access

    Avatar de Arkham46
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    5 865
    Détails du profil
    Informations personnelles :
    Localisation : France, Loiret (Centre)

    Informations forums :
    Inscription : Septembre 2003
    Messages : 5 865
    Points : 14 524
    Points
    14 524
    Par défaut
    slt,

    la fonction standard IsNumeric ne convient pas??

    si STREET_1 est un champ text il faut sans doute le convertir :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SET HOUSE_NO_1 = val(STREET_1)

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    144
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 144
    Points : 54
    Points
    54
    Par défaut
    je ne connaisait pas le fonction standard IsNumeric
    mais je vais essayé, je suis sous access 97

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    144
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 144
    Points : 54
    Points
    54
    Par défaut
    EN fait, les deux champs sont de type text
    et je veux que la mise a jour se fasse
    lorsque le premier caractere de STREET_1
    est un numérique
    je ne comprend pas ou est mon erreur

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    144
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 144
    Points : 54
    Points
    54
    Par défaut
    Je pense que c'est à cause du fait qu'il y est des
    champs null dans STREET_1
    est ce que quelq'un sait comment tester si un champ est null
    j'avais pensé à
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    If Strna = "" Then
        Exit Function
      End If
    mais ça ne marche pas..

  6. #6
    Responsable Access

    Avatar de Arkham46
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    5 865
    Détails du profil
    Informations personnelles :
    Localisation : France, Loiret (Centre)

    Informations forums :
    Inscription : Septembre 2003
    Messages : 5 865
    Points : 14 524
    Points
    14 524
    Par défaut
    slt,

    peut-être simplement avec IsNumeric et Nz

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    UPDATE Data2 
    SET HOUSE_NO_1 = STREET_1
    WHERE IsNumeric(Nz(STREET_1));

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    144
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 144
    Points : 54
    Points
    54
    Par défaut
    la il n'y a pas d'erreur mais le champ HOUSE_NO_1
    ne bouge pas lol

    exemple: Si STREET_1 = 16 avenue henri fabre

    Alors HOUSE_NO_1 doit prendre cette valeur

  8. #8
    Responsable Access

    Avatar de Arkham46
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    5 865
    Détails du profil
    Informations personnelles :
    Localisation : France, Loiret (Centre)

    Informations forums :
    Inscription : Septembre 2003
    Messages : 5 865
    Points : 14 524
    Points
    14 524
    Par défaut
    ah ben alors pour tester le premier caractère :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    UPDATE Data2 
    SET HOUSE_NO_1 = STREET_1
    WHERE IsNumeric(Left(Nz(STREET_1),1));

  9. #9
    Membre émérite

    Profil pro
    Inscrit en
    Février 2005
    Messages
    1 751
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 1 751
    Points : 2 368
    Points
    2 368
    Par défaut
    Bonjour,

    Tu pourrais conserver ta fonction mais en tenant compte des valeurs Null.
    Le paramètre Prefix est de type Variant, ce qui évite l'erreur "Type mismatch".

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    Function IsNumerique(ByVal Prefix As Variant) As Integer
        If IsNull(Prefix) Then
            IsNumerique=0
        ElseIf ((Asc(Prefix) >= 48) And (Asc(Prefix) <= 57)) Then
            IsNumerique = 1
        Else
            IsNumerique = 0
        End If
    End Function

  10. #10
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    144
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 144
    Points : 54
    Points
    54
    Par défaut
    ok sa marche super
    merci a tous
    les deux dernieres réponses postés sont correctes


    Did

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Debutant] Probleme avec requete UPDATE
    Par xavDIP dans le forum VB.NET
    Réponses: 2
    Dernier message: 20/06/2007, 11h46
  2. [MySQL] Probleme avec requete UPDATE
    Par Chromatic dans le forum PHP & Base de données
    Réponses: 18
    Dernier message: 09/02/2006, 13h17
  3. Probleme avec requete UPDATE sur ACCESS
    Par Chromatic dans le forum VBA Access
    Réponses: 2
    Dernier message: 05/01/2006, 10h03
  4. Probleme avec l'update
    Par belabyad dans le forum ASP
    Réponses: 8
    Dernier message: 02/05/2005, 10h18
  5. probleme avec requete sql aime pas les strings
    Par lil_jam63 dans le forum Bases de données
    Réponses: 3
    Dernier message: 24/02/2004, 14h45

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