以下SQL 语句是实现: 如果DB2中不存在表Area, 则将DB1中的表Area 复制到DB2中,并且添加新列Bakdate,默认值为当前日期; 如果DB2中已经存在表Area, 则将DB1中Area中的记录插入到DB2的Area表中. 注:这条语句会每个月执行一次.
但是报错,列名或所提供值的数目与表定义不区配.
除了在insert 语句中逐一列出列名以外,是否有其它解决办法? 请指教,先谢了!!
IF NOT EXISTS(SELECT Name FROM sysobjects WHERE type='u' AND ID=object_id('Area'))
BEGIN
SELECT * INTO DB2..Area FROM DB1..Area
ALTER TABLE Area
ADD BakDate datetime
Constraint Area_DefaultDate
Default (getdate() ) WITH VALUES
END
ELSE
BEGIN
INSERT INTO Area
SELECT *, getdate() FROM DB1..Area
END