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

MS SQL Server Discussion :

TSQL - sql server 200 - error syntax


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 56
    Par défaut TSQL - sql server 200 - error syntax
    Bonjour,

    j'ai un problème que PS sous SQL SERVER 2000, voici le code :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    set dateformat ymd
    DECLARE @err INT
    DECLARE @SQL_STATEMENT varchar(8000)
    begin tran
     
     
    INSERT INTO IntraqualDev.Intraqual.M83 (CH1) VALUES ('Asep  1 2008 12:00AM')
     
    IF (@@ERROR <> 0) OR (@@ROWCOUNT = 0) PRINT 'ERREUR'
    rollback tran
    Résultat affichage :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Serveur : Msg 245, Niveau 16, État 1, Ligne 1
    Syntax error converting the varchar value 'Asep  1 2008 12:00AM' to a column of data type int.
    Cependant, je n'arrive pas à récupérer le code error de cette transaction lorsque la syntaxe de la requête n'est pas bonne.

    Merci pour votre aide.

  2. #2
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Par défaut
    Bonjour,

    Dans SQL Server, par défaut, toute instruction de modification de données est une transaction.
    Donc vous n'avez pas besoin d'encadrer votre INSERT par un BEGIN TRAN ... COMMIT TRAN.
    Si une erreur se produit, l'instruction sera annulée, comme si elle n'avait jamais eu lieu.
    Votre insertion ne fonctionne pas parce que le A dans votre chaîne représentant la date ne doit pas y être :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO IntraqualDev.Intraqual.M83 (CH1) VALUES ('sep  1 2008 12:00AM)
    Le mieux serait que vous utilisez le format ISO de dates : YYYYMMDD HH:mm:ss
    Vous pouvez l'obtenir d'une colonne de type DATETIME de la façon suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SELECT CONVERT(CHAR(8), maColonneDate, 112)
    FROM dbo.maTable
    @++

  3. #3
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 454
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 454
    Par défaut
    Je crois qu'il cherche justement à récupérer le code erreur, c'est pour celà qu'il en provoque une volontairement.

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 56
    Par défaut
    effectivement, j'ai rajouté un mauvais format date pour essayer de récupérer le code error et faire un roll back.

Discussions similaires

  1. Attachement d'un fichier MDE à Sql server 200
    Par jdiaga68 dans le forum Développement
    Réponses: 0
    Dernier message: 19/12/2008, 14h46
  2. [SQL Server 2005] Error:2147749891 (0x80041003)
    Par xavier51 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 11/10/2008, 17h31
  3. Wifi avec sql server 200
    Par badrel dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 29/04/2006, 14h48
  4. [SQL Server 2000] error lors d'un select
    Par ardi dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 10/04/2006, 08h39
  5. création d'utilisateur et Connexion sur SQL Server 200
    Par da_latifa dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 24/07/2005, 11h26

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