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

Développement SQL Server Discussion :

Problème d'insertion sur table avec une unique colonne identity [2008R2]


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre expérimenté
    Avatar de Kropernic
    Homme Profil pro
    Analyste / Programmeur / DBA
    Inscrit en
    Juillet 2006
    Messages
    3 932
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Belgique

    Informations professionnelles :
    Activité : Analyste / Programmeur / DBA
    Secteur : Distribution

    Informations forums :
    Inscription : Juillet 2006
    Messages : 3 932
    Par défaut Problème d'insertion sur table avec une unique colonne identity
    Bonjour,

    Comment insérer plusieurs lignes avec un seul ordre INSERT dans une table comportant juste une colonne identity ?

    Pour insérer une ligne, c'est facile :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO LA_TABLE DEFAULT VALUES
    Mais je voudrais pouvoir faire des insertions ensemblistes et non itératives...

    Un exemple concret avec le DDL suivant qui comprend la table posant problème (T_NATIONALITE_NAT), une table qui la référence (T_NATIONALITE_LNG_NAL) et une vue qui fait la jointure des deux (V_NATIONALITE_VNT) :
    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
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    CREATE TABLE [dbo].[T_NATIONALITE_NAT](
        [NAT_ID] [int] IDENTITY(1,1) NOT NULL,
    PRIMARY KEY CLUSTERED 
    (
        [NAT_ID] ASC
    )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
    ) ON [PRIMARY]
     
    GO
     
    CREATE TABLE [dbo].[T_NATIONALITE_LNG_NAL](
        [NAT_ID] [int] NOT NULL,
        [LNG_ID] [tinyint] NOT NULL,
        [NAL_LIB] [varchar](50) NOT NULL,
    PRIMARY KEY CLUSTERED 
    (
        [NAT_ID] ASC,
        [LNG_ID] ASC
    )WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
    ) ON [PRIMARY]
     
    GO
     
    SET ANSI_PADDING OFF
    GO
     
    ALTER TABLE [dbo].[T_NATIONALITE_LNG_NAL]  WITH CHECK ADD  CONSTRAINT [FK_T_NATIONALITE_LNG_NAL_LNG_ID] FOREIGN KEY([LNG_ID])
    REFERENCES [dbo].[T_LANGUAGE_LNG] ([LNG_ID])
    GO
     
    ALTER TABLE [dbo].[T_NATIONALITE_LNG_NAL] CHECK CONSTRAINT [FK_T_NATIONALITE_LNG_NAL_LNG_ID]
    GO
     
    ALTER TABLE [dbo].[T_NATIONALITE_LNG_NAL]  WITH CHECK ADD  CONSTRAINT [FK_T_NATIONALITE_LNG_NAL_NAT_ID] FOREIGN KEY([NAT_ID])
    REFERENCES [dbo].[T_NATIONALITE_NAT] ([NAT_ID])
    GO
     
    ALTER TABLE [dbo].[T_NATIONALITE_LNG_NAL] CHECK CONSTRAINT [FK_T_NATIONALITE_LNG_NAL_NAT_ID]
    GO
     
    CREATE VIEW [dbo].[V_NATIONALITE_VNT]
    AS
    SELECT
            NAT.NAT_ID,
            LNG_ID,
            NAL_LIB
    FROM
            DBO.T_NATIONALITE_NAT NAT
                INNER JOIN DBO.T_NATIONALITE_LNG_NAL NAL
                    ON    NAT.NAT_ID = NAL.NAT_ID
    GO
    L'idée est donc de placer un trigger instead of insert et update sur la vue pour permettre d'effectuer les insertions et mises à jour correctement (qui à priori ne devraient pas être nombreuses, je vous l'accorde).

    Mais je bloque sur l'instruction à utiliser pour insérer de manière ensembliste dans la table dont le suffixe est NAT...

  2. #2
    Expert confirmé
    Avatar de mikedavem
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2005
    Messages
    5 450
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ain (Rhône Alpes)

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

    Informations forums :
    Inscription : Août 2005
    Messages : 5 450
    Par défaut
    Quelle version de SQL Server utilises-tu ?

    De plus quel est l'intérêt du point de vue sémantique dans ton cas d'avoir une table avec une seule colonne identity ?

    ++

  3. #3
    Membre expérimenté
    Avatar de Kropernic
    Homme Profil pro
    Analyste / Programmeur / DBA
    Inscrit en
    Juillet 2006
    Messages
    3 932
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Belgique

    Informations professionnelles :
    Activité : Analyste / Programmeur / DBA
    Secteur : Distribution

    Informations forums :
    Inscription : Juillet 2006
    Messages : 3 932
    Par défaut
    Citation Envoyé par mikedavem Voir le message
    Quelle version de SQL Server utilises-tu ?
    2008R2 (c'est dans le titre )
    Citation Envoyé par mikedavem Voir le message
    De plus quel est l'intérêt du point de vue sémantique dans ton cas d'avoir une table avec une seule colonne identity ?
    En cas d'évolution du modèle, il est alors possible d'ajouter des propriétés à chaque nationalité sans avoir à les répéter pour chaque langue.

    Par exemple, j'ai déjà envisagé d'ajouter une colonne faisant référence à la table T_PAYS_PAY pour indiquer le pays correspondant à cette nationalité.

  4. #4
    Expert confirmé
    Avatar de mikedavem
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2005
    Messages
    5 450
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ain (Rhône Alpes)

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

    Informations forums :
    Inscription : Août 2005
    Messages : 5 450
    Par défaut
    2008R2 (c'est dans le titre )
    Je ne m'y habitue pas aux versions avant les titres

    En cas d'évolution du modèle, il est alors possible d'ajouter des propriétés à chaque nationalité sans avoir à les répéter pour chaque langue.
    Par exemple, j'ai déjà envisagé d'ajouter une colonne faisant référence à la table T_PAYS_PAY pour indiquer le pays correspondant à cette nationalité.
    Tu la mettrais où cette nouvelle colonne ?

    ++

  5. #5
    Membre expérimenté
    Avatar de Kropernic
    Homme Profil pro
    Analyste / Programmeur / DBA
    Inscrit en
    Juillet 2006
    Messages
    3 932
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Belgique

    Informations professionnelles :
    Activité : Analyste / Programmeur / DBA
    Secteur : Distribution

    Informations forums :
    Inscription : Juillet 2006
    Messages : 3 932
    Par défaut
    Bah dans la table T_NATIONALITE_NAT...

    En faisant quelque chose du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    ALTER TABLE dbo.T_NATIONALITE_NAT
    ADD PAY_ID SMALLINT NOT NULL;
    GO
     
    ALTER TABLE dbo.T_NATIONALITE_NAT
    ADD CONSTRAINT FK_T_NATIONALITE_NAT_PAY_ID FOREIGN KEY (PAY_ID)
        REFERENCES dbo.T_PAYS_PAY (PAY_ID);
    GO
    Je ne comprends pas bien le pourquoi de ces questions. Surtout venant quelqu'un que je sais très expérimenté. Je pensais ces pratiques courantes et normales....

  6. #6
    Expert confirmé
    Avatar de mikedavem
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2005
    Messages
    5 450
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ain (Rhône Alpes)

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

    Informations forums :
    Inscription : Août 2005
    Messages : 5 450
    Par défaut
    Ok donc pourquoi ne pas dans ce cas ajouter directement une colonne "dummy" ou directement ta colonne concernant le pays car cela t'évitera de modifier par la suite ton code d'insertion.

    Le problème c'est qu'avec une seule colonne identity il faut ruser un peu et utiliser par exemple un MERGE puisque tu es sur 2008 R2 .. quelque chose du genre (à tester avec le trigger) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    MERGE INTO dbo.T_NATIONALITE_NAT
    USING (SELECT col ... 
              FROM INSERTED)
    ON 1 = 0
    WHEN NOT MATCHED 
     THEN INSERT DEFAULT VALUES
    OUTPUT INSERTED.id .....
    .. ce qui rend le code un peu lourd ... alors que si tu as déjà une autre colonne le code sera plus simple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    INSERT dbo.T_NATIONALITE_NAT (dummy / pays_id)
    SELECT col ...
    FROM inserted
    ++

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 29/10/2013, 15h44
  2. Probléme d'insertion en lot avec une seul requete
    Par No Name dans le forum ADO.NET
    Réponses: 3
    Dernier message: 12/03/2011, 18h24
  3. Problème pour insertion dans tables avec jointure
    Par C3DRIC49 dans le forum Langage
    Réponses: 8
    Dernier message: 15/10/2010, 21h52
  4. lenteur sur table avec beaucoup de colonne
    Par ukanoldai dans le forum Oracle
    Réponses: 3
    Dernier message: 23/01/2007, 13h36
  5. Réponses: 2
    Dernier message: 14/05/2004, 14h32

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