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 :

DBI et BULK INSERT sur SQL Server


Sujet :

SGBD Perl

  1. #1
    Membre régulier Avatar de elvivo
    Inscrit en
    Mai 2002
    Messages
    105
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 105
    Points : 104
    Points
    104
    Par défaut DBI et BULK INSERT sur SQL Server
    Salut,

    J'ai besoin d'executer un bulk insert d'un fichier dans une table de ma base sur sql server.
    Tout marche bien mais en executant pas a pas je me suis rendu compte que lorsque j'appelle execute de DBI sur mon statement, les donnees sont inserees malgre le fait que je n'ai pas appele commit.

    J'ai regarde dans les docs de DBI. Autocommit est bien a 0 au moment de mon execute et dans la doc de sql server je ne trouve rien pour forcer le bulk a respecter la transaction.

    Quelqu'un a t il une idee ?

    Le code est le suivant:
    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
     
    my $Statement = "BULK INSERT $dbname.$tablename
    FROM '$Path'
    WITH
    (
        FIELDTERMINATOR = ';'
        , ROWTERMINATOR = '\n'
    )
    " ;
    warn $Statement."\n" ;
    $DBObj->begin_work() ;
    my $Sth = $DBObj->prepare($Statement) ;
    my $Result = $Sth->execute() 
    if ($Result and $Result == 100)
    {
        $Sth->commit() ;
    }
    else
    {
        $Sth->rollback() ;
    }
    In code we trust !!

  2. #2
    Jeh
    Jeh est déconnecté
    Membre actif Avatar de Jeh
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    203
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations forums :
    Inscription : Septembre 2003
    Messages : 203
    Points : 250
    Points
    250
    Par défaut
    Salut !!

    La méthode execute est recommandée pour les selections mais pas pour les opérations d'insertion, modification, suppression. As-tu essayé avec la méthode "do" ?
    Verre vide je te plains, verre plein, je te vide.

  3. #3
    Membre régulier Avatar de elvivo
    Inscrit en
    Mai 2002
    Messages
    105
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 105
    Points : 104
    Points
    104
    Par défaut
    Non mais je vais le faire !
    Merci. Je met le resolu si ca marche.
    In code we trust !!

  4. #4
    Membre régulier Avatar de elvivo
    Inscrit en
    Mai 2002
    Messages
    105
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 105
    Points : 104
    Points
    104
    Par défaut
    En fait do ne m'arrange pas car il commit automatiquement les modifications.

    Je vais plutot faire une store proc qui me bulk le bazard et gere sa propre transaction.

    En tout cas merci !
    In code we trust !!

  5. #5
    Jeh
    Jeh est déconnecté
    Membre actif Avatar de Jeh
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    203
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations forums :
    Inscription : Septembre 2003
    Messages : 203
    Points : 250
    Points
    250
    Par défaut
    Citation Envoyé par elvivo
    En fait do ne m'arrange pas car il commit automatiquement les modifications.

    Je vais plutot faire une store proc qui me bulk le bazard et gere sa propre transaction.

    En tout cas merci !
    Bah en fait, la méthode "do" de fait pas de commit automatique...
    Ton problème doit venir soit de la conf de la bd soit du driver utilisé par Perl.

    Quoi qu'il en soit, bon courage !
    Verre vide je te plains, verre plein, je te vide.

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

Discussions similaires

  1. [AC-2013] Problème Insertion sur SQL server (WebApp)
    Par clickandgo dans le forum Projets ADP
    Réponses: 0
    Dernier message: 16/01/2015, 20h11
  2. Insertion de données d'un TextBox Windows Form sur Sql Server
    Par CaptainSmoker dans le forum Windows Forms
    Réponses: 5
    Dernier message: 10/05/2010, 11h46
  3. Réponses: 0
    Dernier message: 17/03/2010, 17h45
  4. Triggers sur insertion avec SQL Server 2005
    Par Naail dans le forum Développement
    Réponses: 14
    Dernier message: 01/07/2009, 15h23
  5. Insertion du caractere euro sur SQL Server 2005 Express
    Par solidxiii dans le forum MS SQL Server
    Réponses: 7
    Dernier message: 26/06/2008, 10h37

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