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

SGBD Perl Discussion :

[sgbd] [Oracle] Pb d'execution d'une requete


Sujet :

SGBD Perl

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 171
    Points : 70
    Points
    70
    Par défaut [sgbd] [Oracle] Pb d'execution d'une requete
    Bonjour,

    J'execute une requete de mise a jour, mais la modification n'est pas prise en compte.

    Voici mon code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    my $res = FONCTION->bd_change($login, $pass, "update table set champ1='$champ1', champ2='$champ2' where gen_id=$gen_id"); 
     
    print "REQUETE : update table set champ1='$champ1', champ2='$champ2' where gen_id=$gen_id"; 
     
        if ($res ne 'ok')  
          { 
            print "  <i>Impossible add</i>"; 
          } 
        else  
          { 
            print "  <i>Confirmed add</i>";
          }
    Et le code de la fonction bd_change :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    sub bd_change{  
      my $login = $_[1];  
      my $pass = $_[2];  
      $dbh = DBI->connect('Dbi:Oracle:',$login,$pass,{  
                                                      PrintError => 1, # warn() on errors  
                                                      RaiseError => 0, # don't die on error  
                                                      AutoCommit => 0, # don't commit executes immediately  
                                                     }) ;#or die "ERROR : couldn't connect to database ", DBI::errstr;  
      my $sql =  $_[3];  
      if ($dbh)  
        {  
     
          my $nb = $dbh->do($sql) or warn "le do ne marche pas dans bd_change\n";  
          $dbh->commit;  
          $dbh->disconnect();  
          if ($nb ne 0) 
            {  
              return ("ok");  
            } 
          else 
           {
                return "error2";}  
           } 
      else  
        {  
          return ("error");  
        }  
    }
    J'ai fait un print de la requete comme indiqué dans le 1er code, et la requete s'affiche correctement. Lorsque je fais un copier-coller pour la traiter directement avec Oracle, ca marche bien.

    Apparement, $nb est vide. Je l'ai fait affiché, et rien n'apparait...

    Merci

  2. #2
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 498 771
    Points
    498 771

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 171
    Points : 70
    Points
    70
    Par défaut
    J'ai essayé, mais le probleme reste le meme...

  4. #4
    Responsable Perl et Outils

    Avatar de djibril
    Homme Profil pro
    Inscrit en
    Avril 2004
    Messages
    19 820
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 19 820
    Points : 498 771
    Points
    498 771
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $dbh = DBI->connect('Dbi:Oracle:',$login,$pass,{
    t'as pas oublié le nom de ta base????????
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $dbh = DBI->connect('Dbi:Oracle:nom_de_la_base',$login,$pass,{

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 171
    Points : 70
    Points
    70
    Par défaut
    Citation Envoyé par djibril
    t'as pas oublié le nom de ta base????????
    J'utilise une fonction similaire, mais pour faire un select, et ca marche tres bien. Donc, je ne pense pas que ca vienne de la.

    Est ce que ca pourrait etre une question de privileges sur la base?

  6. #6
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 171
    Points : 70
    Points
    70
    Par défaut
    C'était bien un probleme de droits.

    J'avais la possibilité de faire des selects, mais pas de update, delete ou insert.

    Mon code était donc correct, pas besoin de rajouter le nom de la base de données.

    Merci djibril.

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

Discussions similaires

  1. Execution d'une requete sur un resultat précédent
    Par Systemic7 dans le forum Langage SQL
    Réponses: 6
    Dernier message: 02/08/2005, 14h43
  2. [Procedure stocké] Execution d'une requete
    Par duran2004 dans le forum SQL
    Réponses: 2
    Dernier message: 24/06/2005, 13h26
  3. pb d'execution d'une requete sql
    Par pit9.76 dans le forum Bases de données
    Réponses: 2
    Dernier message: 26/06/2004, 12h03
  4. Probleme d'execution d'une requete avec un Count
    Par PrinceMaster77 dans le forum ASP
    Réponses: 4
    Dernier message: 23/06/2004, 10h33
  5. [ADO] Probleme lors de l'execution d'une requete...
    Par NoisetteProd dans le forum Bases de données
    Réponses: 4
    Dernier message: 04/06/2004, 12h43

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