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

Administration et Installation Discussion :

Erreur lors d'un update d'une table sql serveur en liaison ODBC avec SAS


Sujet :

Administration et Installation

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    45
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mai 2008
    Messages : 45
    Points : 31
    Points
    31
    Par défaut Erreur lors d'un update d'une table sql serveur en liaison ODBC avec SAS
    Bonjour à tous,

    Je travail actuellement sur une base SQL serveur 2005. J'ai des erreurs d'identifiants que je dois cleaner. Pour un soucis de traçabilité, on a décider de faire ces modifications via SAS (en liaison ODBC avec la table du serveur).

    Une fois la liaison faite, je lance ma proc sql dans sas :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    proc sql;
     
    UPDATE TOTO.titi SET centre = 2
    WHERE ((centre=1) AND (numero=1));
     
    quit;
    Mais SAS me met :
    ERROR: CLI cursor fetch error: [DataDirect][ODBC SQL Server
    Driver]Connection is busy with results for another hstmt
    J'ai regarder sur internet et j'ai vu que c'était du à un problème avec SQL serveur via ODBC qui ne peut lançer qu'une requête à la fois (enfin c'est ce que j'ai compris).

    sur le support SAS http://support.sas.com/kb/33/797.html, ils disent :
    This error occurs because an update trigger that is defined in the SQL Server table generates multiple results during the update process.

    The SQL Server database only permits one active statement per connection, and an active result (most like a row count) might already exist. As a result, the next fetch to process the next update returns the error message.

    As a workaround, you can use the following SQL Server option at the top of the trigger code:

    set nocount on
    J'ai essayer de de placer ce "set nocount on" un peu partout dans ma proc SQL mais j'ai pas réussi à trouver comment le mettre, SAS me met :
    ERROR 73-322: Expecting an =.

    ERROR 76-322: Syntax error, statement will be ignored.
    Est-ce que quelqu'un aurait une idée sur l'emplacement où le mettre ou tout simplement la résolution de ce problème?

    Merci d'avance

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    747
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2009
    Messages : 747
    Points : 978
    Points
    978
    Par défaut
    Salut,

    Pour passer des options tu peux utiliser le "EXECUTE BY" avec le mot clef "SET".

    par contre ta requête tu peux la faire directement entièrement par SQL serveur quelque chose dans le genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    proc sql;
       connect to  odbc(dsn=xxx);
       execute (update titi SET centre = 2
    WHERE ((centre=1) AND (numero=1))
    )
               by remote;
     
    space
    Doc : EXECUTE
    Exemple : PROC SQL Pass-Through facility
    Tcho,

    Xav

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    45
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mai 2008
    Messages : 45
    Points : 31
    Points
    31
    Par défaut
    J'ai essayer comme tu as dit en utilisant la commande execute :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    proc sql;
     
    EXECUTE (UPDATE TOTO.titi SET centre = 2
                 WHERE ((centre=1) AND (numero=1)))
    BY remote;
     
    quit;
    mais ça marche pas, il me dit :
    ERROR: SERVER= option, required for connection, not found.
    alors que ma connection à l'odbc est faite depuis un libname (qui fonctionne).

    Sinon, j'ai essayer de remplacer le remote par "set" mais ça fonctionne pas non plus.

    Pourrais-tu me détailler plus où mettre les options et à quoi sert le "server=" que SAS me demande?

  4. #4
    Membre éprouvé
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    747
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2009
    Messages : 747
    Points : 978
    Points
    978
    Par défaut
    Tu as deux méthodes pour accéder à des tables dans un DBMS:

    Le libname ou le Remote SQL Pass Through (RSPT)

    Le RSPT permet un plus grand contrôle des options et du SQL envoyé à la base.

    See : RSPT

  5. #5
    Rédacteur

    Homme Profil pro
    SAS ALLIANCE SILVER. Consultant et formateur SAS et Cognos.
    Inscrit en
    Avril 2009
    Messages
    2 497
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : SAS ALLIANCE SILVER. Consultant et formateur SAS et Cognos.
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2009
    Messages : 2 497
    Points : 6 064
    Points
    6 064
    Par défaut
    Remarque 1 : si tu fais un EXECUTE, le SQL serveur travaillera hermétiquement, ie. sans SAS. Par conséquent, il faut que TOTO.TITI soit une table SQL et non une table SAS TITI dans une bib. SAS TOTO.

    Remarque 2 : Xavier a indiqué connect TO odbc(dsn=xxx); en plus du reste, si tu essaies de tester, il faut faire de même : c'est la demande de connexion au serveur !
    Je mettrai d'ailleurs
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    proc sql;
       connect TO  odbc(dsn=xxx);
       execute (UPDATE titi SET centre = 2
    WHERE ((centre=1) AND (numero=1))
    )  BY odbc;
    N'oubliez pas de cliquer sur lorsque votre problème est réglé !

  6. #6
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    45
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mai 2008
    Messages : 45
    Points : 31
    Points
    31
    Par défaut
    Merci pour ces précisions, ça marche nickel

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

Discussions similaires

  1. erreur lors de la creation d'une table en utilisant UNSIGNED
    Par buzzyLazy dans le forum Requêtes
    Réponses: 2
    Dernier message: 01/08/2008, 17h06
  2. Erreur lors de l'ajout dans une table
    Par k_boy dans le forum Bases de données
    Réponses: 14
    Dernier message: 31/03/2008, 15h05
  3. erreur lors d'un update d'une base de données
    Par tibtibby dans le forum ASP
    Réponses: 1
    Dernier message: 09/06/2006, 14h30
  4. Réponses: 3
    Dernier message: 07/12/2005, 14h28
  5. Erreur lors de l'ajout d'une table
    Par FredMines dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 27/07/2005, 13h13

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