--根据基本表结构及其数据生成INSERT...的SQL create proc spGenInsertSQL @TableName as varchar(100) as 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)
create proc spGenInsertSQL
@TableName as varchar(100)
as
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)
蛮好用的。
我确实是要生成带有数据的 SQL 脚本~ 处于刚刚学习的阶段~ 谢谢大家了~~