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 :

perl DBI::Sqlite et foreign_keys


Sujet :

SGBD Perl

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    75
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2009
    Messages : 75
    Points : 159
    Points
    159
    Par défaut perl DBI::Sqlite et foreign_keys
    Bonjour,

    J'ai un soucis avec un script Perl pour activer les clefs étrangères.
    Le script s'exécute sans erreur. Normalement il doit s'arreter car erreur de contrainte clef etrangère.

    Mais, lorsque je lance les deux tests (voir le fichier perl) sur une console sqlite, j'obtient bien les deux erreurs
    Je suis sous windows XP
    activePerl : 5.8.0
    SQlite : 3.7.3

    Je ne sais pas comment débugguer ce problème

    Merci d'avance

    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
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
     
    #!perl -w
    use strict;
    use DBI;
     
    my $dbfile="test.db";
    my $dsn = "dbi:SQLite:dbname=$dbfile";
    my $username = "";
    my $password = "";
    my %attr = ( RaiseError => 1, AutoCommit => 0 );
    my $dbh = DBI->connect($dsn, $username, $password,\%attr ) ;
    # FK
    $dbh->do("pragma foreign_keys=ON;");
    #artist
    $dbh->do("DROP TABLE IF EXISTS artist");
    $dbh->do("DROP TABLE IF EXISTS track");
    $dbh->do("CREATE TABLE artist(
      artistid    INTEGER PRIMARY KEY, 
      artistname  TEXT
    )");
    $dbh->do("INSERT INTO artist VALUES(1, 'Dean Martin')");
    $dbh->do("INSERT INTO artist VALUES(2, 'Frank Sinatra')");
    #track
    $dbh->do("CREATE TABLE track(
      trackid     INTEGER PRIMARY KEY, 
      trackname   TEXT, 
      artist INTEGER NOT NULL,
      FOREIGN KEY(artist) REFERENCES artist(artistid)
    )");
    $dbh->do("INSERT INTO track VALUES(1, 'That''s Amore', 1 )");
    $dbh->do("INSERT INTO track VALUES(2, 'Christmas Blues', 1 )");
    $dbh->do("INSERT INTO track VALUES(3, 'My Way', 2 )");
     
    # TEST 1 
    $dbh->do("INSERT INTO track VALUES(14, 'Mr. Bojangles', 3)");
    $dbh->do("DELETE FROM artist WHERE artistid=2");
     
    $dbh->commit;
    $dbh->disconnect;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    sqlite> pragma foreign_keys=ON;
    sqlite> INSERT INTO track VALUES(14, 'Mr. Bojangles', 3);
    Error: foreign key constraint failed
    sqlite> DELETE FROM artist WHERE artistid=2;
    Error: foreign key constraint failed

  2. #2
    Membre confirmé
    Avatar de cmcmc
    Homme Profil pro
    Inscrit en
    Juillet 2013
    Messages
    316
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juillet 2013
    Messages : 316
    Points : 641
    Points
    641
    Par défaut
    testé avec ActivePerl 5.12, Cygwin perl 5.10, Strawberry perl 5.16.1.3 32bits, ton script sort en erreur (foreign key constraint failed).

    Essaie peut-être avec une version plus récente de Active Perl...
    Sauf indication contraire tous les codes que je présente sont utilisables et testés (mais sans garantie d'aucune sorte)
    J'apporte beaucoup de soin à la rédaction de mes posts et apprécie les retours donc merci de s'il vous paraissent pertinents ou utiles
    Lazyness, Impatience and Hubris are good for you

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    75
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2009
    Messages : 75
    Points : 159
    Points
    159
    Par défaut
    Merci pour votre réponse,

    En fait, je n'ai pas précisé dans mon message, que j'ai un poste utilisateur sans droit d'admin il y a cette version de perl installée sur ma machine, je ne peux pas malheureusement installer autre chose qu'en mode portable.

    Je vais essayer avec Strawberry Perl en mode portable (version dev) si ça marche. Normalement ça devrait, à part si je retrouve d'autres problèmes liés à la restriction de droit ;(

    Linuxien en galère avec une machine Windows sans droit d'admin

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    75
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2009
    Messages : 75
    Points : 159
    Points
    159
    Par défaut
    C'est un peu bizzar !
    J'ai utilisé Strawberry perl en mode portable 5.10.0 et c'est pareil pas d'erreur lorsque je lance ma commande, je me demande si le PRAGMA foreigne_keys=ON est pris en compte!

    Aussi, le SQLite est en mode portable !

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

Discussions similaires

  1. [PERL] DBI DBD::ORACLE compatibilite Windows Unix
    Par theyankee76 dans le forum SGBD
    Réponses: 10
    Dernier message: 09/05/2007, 11h13
  2. Drivers SQL server pour Perl DBI ?
    Par panaone dans le forum SGBD
    Réponses: 14
    Dernier message: 05/05/2006, 22h29
  3. Problème d'insertion de données Perl-dbi
    Par Tygrou dans le forum SGBD
    Réponses: 5
    Dernier message: 07/04/2006, 11h20
  4. [sgbd] Perl-DBI
    Par perlgirl dans le forum SGBD
    Réponses: 5
    Dernier message: 17/11/2004, 10h04

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