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 :

IDENTITY_INSERT


Sujet :

MS SQL Server

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    93
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2003
    Messages : 93
    Points : 50
    Points
    50
    Par défaut IDENTITY_INSERT
    bonjour,

    j'ai ce message quand j'essaie de faire un INSERT dans une bdd mssql :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Serveur : Msg 544, Niveau 16, État 1, Ligne 1
    Impossible d'insérer une valeur explicite dans la colonne identité de la table 'FAV' quand IDENTITY_INSERT est défini à OFF.
    n'etant pas expert ...

    merci

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    93
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2003
    Messages : 93
    Points : 50
    Points
    50
    Par défaut
    j'ai donc modifié ma requete :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SET INDENTITY_INSERT FAV ON insert into fav  (fav_idx,fav_categ,fav_url,fav_desc,fav_opecode) values('','$favcateg','$favurl','$favdesc','$favopecode') SET INDENTITY_INSERT FAV OFF"
    mais toujours le meme message...

    erreur de syntaxe?

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    93
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2003
    Messages : 93
    Points : 50
    Points
    50
    Par défaut
    du nouveau :

    avec cette requete, fav_idx s'incremente tout seul
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    insert into fav  (fav_categ,fav_url,fav_desc,fav_opecode) values('$favcateg','$favurl','$favdesc','$favopecode')
    j'ai juste zappé le champs fav_idx de la requete...

  4. #4
    Nouveau Candidat au Club
    Inscrit en
    Janvier 2007
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Janvier 2007
    Messages : 1
    Points : 1
    Points
    1
    Par défaut
    Citation Envoyé par ericmart
    bonjour,

    j'ai ce message quand j'essaie de faire un INSERT dans une bdd mssql :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    Serveur*: Msg 544, Niveau 16, État 1, Ligne 1
    Impossible d'insérer une valeur explicite dans la colonne identité de la table 'FAV' quand IDENTITY_INSERT est défini à OFF.
    n'etant pas expert ...

    merci
    salut
    j'ai eu le même message...
    en fait j'ai une clé externe dans la table destination dont la propriété "compteur" est activée je l'ai remis sur 'non' et le tour est joué...
    j'ai en fait copier coller cette colonne d'une autre table et j'ai ommis de mettre à jour cette propriété

  5. #5
    Membre averti Avatar de solo190
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Avril 2007
    Messages
    412
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Consultant informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 412
    Points : 321
    Points
    321
    Par défaut
    on doit juste comprendre que lorsqu'on veut faire une mise à jour dans une Table avec un champ auto incremental , il ne faut pas citer celui-ci dans les colonnes car on ne peu pas le mettre à jour , c'est le SGBD qui se charge de le faire.

  6. #6
    Expert éminent
    Avatar de Lyche
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2007
    Messages
    2 523
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Janvier 2007
    Messages : 2 523
    Points : 6 775
    Points
    6 775
    Billets dans le blog
    4
    Par défaut
    Citation Envoyé par solo190 Voir le message
    on doit juste comprendre que lorsqu'on veut faire une mise à jour dans une Table avec un champ auto incremental , il ne faut pas citer celui-ci dans les colonnes car on ne peu pas le mettre à jour , c'est le SGBD qui se charge de le faire.
    oui et non.

    Oui, lorsqu'il y a une colonne en IDENTITY(x,x) on n'a pas à la citer dans la liste des champs à traiter lors du insert.

    Cependant,

    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    SET IDENTITY_INSERT ON/OFF

    permet de temporairement désactiver l'auto-incrément et de saisir manuellement une valeur.

    Attention toutefois aux données saisies

    Cordialement,
    Lyche

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

Discussions similaires

  1. Copier une table avec IDENTITY_INSERT
    Par [DreaMs] dans le forum MS SQL Server
    Réponses: 12
    Dernier message: 07/11/2007, 15h53
  2. SUNOPSIS V4 SYBASE identity_insert
    Par n.roussaly dans le forum ODI (ex-Sunopsis)
    Réponses: 3
    Dernier message: 01/06/2007, 10h40
  3. SET IDENTITY_INSERT ON/OFF sous Oracle 10g ?
    Par Najdar dans le forum Oracle
    Réponses: 1
    Dernier message: 31/08/2006, 15h05
  4. Insertion impossible a cause de l'IDENTITY_INSERT
    Par oli_carbo dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 22/03/2006, 14h24
  5. Erreur IDENTITY_INSERT
    Par lcf84 dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 04/04/2005, 18h24

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