求助:SQL Server 插入错误:列名或所提供值的数目与表定义不匹配

以下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

posted @ 2009-03-09 10:38  日落无语  阅读(3701)  评论(4编辑  收藏  举报