比如数据库里已经有Table1表,请问用什么方法把这个表的SQL提取出来呢?谢谢!
生成脚本
在企业管理器或查询分析器(2000)中都可以。
数据库->右键->所有任务->生成SQL脚本.
看看选项,把你要的选项选中.
或者只取表的结构的脚本:
表->右键->复制
再打NOTEPAD,粘贴.
从syscolumns表里取得该表的列名,类型,等信息,生成动态sql语句
select * from syscolumns where id = object_id(tablename)
下面的存储过程可以得到,在你的程序中调用这个存储过程就行了.
/*
在查询分析器中调用sqldmo生成脚本--存储过程
--调用实例
declare @str varchar(8000)
exec sp_getscript 服务器名,sa,,数据库名,表名,@str output
print @str
*/
--检测是否存储过程是否存在
if exists(select 1 from sysobjects where id=object_id(sp_getscript) and objectproperty(id,IsProcedure)=1)
drop procedure sp_getscript
go
--创建获取SQL脚本的存储过程.
create procedure sp_getscript
@servername varchar(50) --服务器名
,@userid varchar(50) --用户名,如果为nt验证方式,则为空
,@password varchar(50) --密码
,@databasename varchar(50) --数据库名称
,@objectname varchar(250) --对象名
,@re varchar(8000) output --返回脚本
as
declare @srvid int,@dbsid int --定义服务器、数据库集id
declare @dbid int,@tbid int --数据库、表id
declare @err int,@src varchar(255), @desc varchar(255) --错误处理变量
--创建sqldmo对象
exec @err=sp_oacreate sqldmo.sqlserver,@srvid output
if @err<>0 goto lberr
--连接服务器
if isnull(@userid,)= --如果是 Nt验证方式
begin
exec @err=sp_oasetproperty @srvid,loginsecure,-1
if @err<>0 goto lberr
exec @err=sp_oamethod @srvid,connect,null,@servername
end
else
exec @err=sp_oamethod @srvid,connect,null,@servername,@userid,@password
if @err<>0 goto lberr
--获取数据库集
exec @err=sp_oagetproperty @srvid,databases,@dbsid output
if @err<>0 goto lberr
--获取要取得脚本的数据库id
exec @err=sp_oamethod @dbsid,item,@dbid output,@databasename
if @err<>0 goto lberr
--获取要取得脚本的对象id
exec @err=sp_oamethod @dbid,getobjectbyname,@tbid output,@objectname
if @err<>0 goto lberr
--取得脚本
exec @err=sp_oamethod @tbid,script,@re output
if @err<>0 goto lberr
--print @re
return
lberr:
exec sp_oageterrorinfo NULL, @src out, @desc out
declare @errb varbinary(4)
set @errb=cast(@err as varbinary(4))
exec master..xp_varbintohexstr @errb,@re out
select 错误号=@re, 错误源=@src, 错误描述=@desc
return
go