阅读文章(首页/数据库/sql server教程/)

根据基本表结构及其数据生成INSERT...的SQL

[日期:2005-11-01] 来源:互联网  作者:佚名 [字体: ]

create  proc spGenInsertSQL
@TableName as varchar(100)
as
--declare @TableName varchar(100)
--set @TableName = 'orders'
--set @TableName = 'eeducation'
DECLARE xCursor CURSOR FOR
SELECT name,xusertype
FROM syscolumns
WHERE (id = OBJECT_ID(@TableName))
declare @F1 varchar(100)
declare @F2 integer
declare @SQL varchar(8000)
set @sql ='SELECT 'INSERT INTO ' + @TableName + ' VALUES(''
OPEN xCursor
FETCH xCursor into @F1,@F2
WHILE @@FETCH_STATUS = 0
BEGIN
    set @sql =@sql +
              + case when @F2 IN (35,58,99,167,175,231,239,61) then ' + case when ' + @F1 + ' IS NULL then '' else '''' end + '  else '+' end
              + 'replace(ISNULL(cast(' + @F1 + ' as varchar),'NULL'),'''','''''')'
              + case when @F2 IN (35,58,99,167,175,231,239,61) then ' + case when ' + @F1 + ' IS NULL then '' else '''' end + '  else '+' end
              + char(13) + '',''
    FETCH NEXT FROM xCursor into @F1,@F2
END
CLOSE xCursor
DEALLOCATE xCursor
set @sql = left(@sql,len(@sql) - 5) + ' + ')' FROM ' + @TableName
print @sql
exec (@sql)


阅读:
录入:

评论 】 【 推荐 】 【 打印
上一篇:aboutspaceused
下一篇:BuildData-DrivenWebServiceswithUpdatedXMLSupportforSQLServer2000
相关文章      
本文评论
发表评论


点评: 字数
姓名:

  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款