在SQL2005上生成一个数据库脚本文件,然后在SQL2000上执行的时候,会出现很多的问题:如SQL2005的系统表与 SQL2000的系统表名是有所不同的、sp_addextendedproperty执行时是不需加上"参数=",为了日后学习或是查询方便,记之:
1.找到"WITH (IGNORE_DUP_KEY = OFF) ON "这一句,用全部替代为空
2.找到"sys.objects",用全部替代为"sysobjects"
3.找到"sys.views",用全部替代为"sysobjects"
4.找到"object_id",用全部替代为"id"[注:这里的object_id要区分大小写]
5.找到"sys.sp_addextendedproperty",用全部替代为"dbo.sp_addextendedproperty"或是"sp_addextendedproperty"
6.找到"EXEC sys.sp_addextendedproperty @name=N'XXX', @value=N'XXX' , @level0type=N'SCHEMA', @level0name=N'XXX', @level1type=N'XXX', @level1name =N'XXX'"这一句,将@level0type=N'SCHEMA'改成@level0type=N'user',再把@name=,@value =,@level0type=,@level0name=,@level1type=,@level1name=全部替代为空
在generate script向导下,在select database下有个选项script all object.....,如果此时勾选了,在下面出现的设置窗口里选择script version为sql server 2000,则生成的脚本在2000里运行完全正常。但如果不选这个,而是在后面选择table时勾选select all,然后在script version再选择sql server 2000,则生成的还是2005的脚本......这两种方式生成的脚本应该是一样的吧。