Insérer plusieurs lignes dans une seule requête SQL ?

Insérer plusieurs lignes dans une seule requête SQL ?

Dans SQL Server 2008, vous pouvez insérer plusieurs lignes en utilisant une seule instruction INSERT.

INSERT INTO MyTable ( Column1, Column2 ) VALUES
( Value1, Value2 ), ( Value1, Value2 )

Pour référence, consultez le cours MOC 2778A - Writing SQL Queries in SQL Server 2008.

Par exemple :

INSERT INTO MyTable
  ( Column1, Column2, Column3 )
VALUES
  ('John', 123, 'Lloyds Office'),
  ('Jane', 124, 'Lloyds Office'),
  ('Billy', 125, 'London Office'),
  ('Miranda', 126, 'Bristol Office');

Cette syntaxe est cependant limitée à un maximum de 1 000 lignes. Si vous devez insérer (INSERT) plus de 1 000 lignes, vous pouvez contourner cette limitation en utilisant une table dérivée dans un SELECT à la place, qui n’a pas la même restriction :

`INSERT INTO MyTable ( Column1, Column2, Column3 )
SELECT V.Column1,
V.Column2,
V.Column3
FROM (VALUES(‘John’, 123, ‘Lloyds Office’),
(‘Jane’, 124, ‘Lloyds Office’),
(‘Billy’, 125, ‘London Office’),

(‘Sally’, 10026, ‘Bristol Office’))V(Column1, Column2, Column3);