質問
SQLのInsert Select構造にデフォルト値を渡す方法
テーブルがあります:
create table1 (field1 int, field2 int, field3 int default 1337)
create table2 (field1 int, field2 int)
次のような構成で table2
を table1
に挿入します:
insert into table1 select field1, field2, DEFAULT from table2
タスクを完了するために、私の例で DEFAULT
の代わりに何かを使用することは可能ですか?以前に選択されたテーブルは通常、デフォルト値でどのように挿入されますか?
解決
試用
INSERT INTO table1 (field1, field2)
SELECT field1, field2 FROM table2
SQL Server 2005を使用してこれをテストしました
DECLARE @Table1 TABLE(
field1 INT,
field2 INT,
field3 INT DEFAULT 1337
)
INSERT INTO @Table1 (field1,field2,field3) SELECT 1, 2, 3
DECLARE @Table2 TABLE(
field1 INT,
field2 INT
)
INSERT INTO @Table2 (field1,field2) SELECT 15, 16
INSERT INTO @Table1 (field1,field2)
SELECT field1,
field2
FROM @Table2
SELECT * FROM @Table1
所属していません StackOverflow