如何复制临时表中列的默认约束?

时间:2016-09-21 11:15:29

标签: sql-server database

我尝试使用以下脚本创建临时表

select *
into #Product
from (select * from SalesLT.Product) as data 

创建临时表并将所有值插入新表中。现在我试图在新临时表(#product)中插入一行,但我收到一些字段的错误。

Insert into SalesLT.Product(Name, ProductNumber, StandardCost, ListPrice, ProductCategoryID, SellStartDate)
    values('LED Lights', 'LT-L123', 2.56, 12.99, 37, GETDATE()​)

实际上我在Product表中的其中一个字段Modified Date上有一个默认的日期约束,但是这个约束没有被复制到新的临时表中,所以它抛出异常 无法将值NULL插入“ModifiedDate”列,表'tempdb.dbo。#Product

有没有办法复制临时表中的所有约束?

2 个答案:

答案 0 :(得分:0)

Select into不会复制任何约束,例如Primarykeys,foreign Keys ..在目标表中获取它们的唯一方法是手动编写它们。

select into复制的唯一内容是Identity

select * into dbo.test/#test  from test1--only copies identity

答案 1 :(得分:0)

您不能隐式地“复制”或在临时表上创建约束。您可以考虑通过简单地使用原始表的模式来重新创建临时表作为原始的镜像。然后,您可以以相同的方式重新创建索引和约束。

我会将您指向INFORMATION_SCHEMA.COLUMNS,INFORMATION_SCHEMA.REFERENTIAL_CONSTRAINTS和INFORMATION_SCHEMA.TABLE_CONSTRAINTS作为编码的基础。