成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術(shù)文章
文章詳情頁

如何為SQL Server表數(shù)據(jù)生成insert腳本

瀏覽:103日期:2023-11-04 12:34:47
使用SQL Server數(shù)據(jù)庫自帶的“生成SQL腳本”工具,可以生成創(chuàng)建表、視圖、存儲(chǔ)過程等的SQL腳本。那么,能否將表中的數(shù)據(jù)也生成為SQL腳本,在查詢分析器中執(zhí)行這些腳本后自動(dòng)將數(shù)據(jù)導(dǎo)入到SQL Server中呢?答案是肯定的,示例如下:

CREATE PROCEDURE dbo.OutputData

@tablename sysname

AS

declare @column varchar(1000)

declare @columndata varchar(1000)

declare @sql varchar(4000)

declare @xtype tinyint

declare @name sysname

declare @objectId int

declare @objectname sysname

declare @ident int

set nocount on

set @objectId=object_id(@tablename)

if @objectId is null -- 判斷對(duì)象是否存在

begin

print @tablename + '對(duì)象不存在'

return

end

set @objectname=rtrim(object_name(@objectId))

if @objectname is null or charindex(@objectname,@tablename)=0

begin

print @tablename + '對(duì)象不在當(dāng)前數(shù)據(jù)庫中'

return

end

if OBJECTPROPERTY(@objectId,'IsTable') < > 1 -- 判斷對(duì)象是否是表

begin

print @tablename + '對(duì)象不是表'

return

end

select @ident=status&0x80 from syscolumns where id=@objectid and status&0x80=0x80

if @ident is not null

print 'SET IDENTITY_INSERT '+ @TableName + ' ON'

--定義游標(biāo),循環(huán)取數(shù)據(jù)并生成Insert語句

declare syscolumns_cursor cursor for

select c.name,c.xtype from syscolumns c

where c.id=@objectid

order by c.colid

--打開游標(biāo)

open syscolumns_cursor

set @column=''

set @columndata=''

fetch next from syscolumns_cursor into @name,@xtype

while @@fetch_status <> -1

begin

if @@fetch_status <> -2

begin

if @xtype not in(189,34,35,99,98) --timestamp不需處理,image,text,ntext,sql_variant 暫時(shí)不處理

begin

set @column=@column +

case when len(@column)=0 then ''

else ','

end + @name

set @columndata = @columndata +

case when len(@columndata)=0 then ''

else ','','','

end +

case when @xtype in(167,175) then '''''''''+'+@name+'+''''''''' --varchar,char

when @xtype in(231,239) then '''N''''''+'+@name+'+''''''''' --nvarchar,nchar

when @xtype=61 then '''''''''+convert(char(23),'+@name+',121)+''''''''' --datetime

when @xtype=58 then '''''''''+convert(char(16),'+@name+',120)+''''''''' --smalldatetime

when @xtype=36 then '''''''''+convert(char(36),'+@name+')+''''''''' --uniqueidentifier

else @name

end

end

end

fetch next from syscolumns_cursor into @name,@xtype

end

close syscolumns_cursor

deallocate syscolumns_cursor

set @sql='set nocount on select ''insert '+@tablename+'('+@column+') values(''as ''--'','+@columndata+','')'' from '+@tablename

print '--'+@sql

exec(@sql)

if @ident is not null

print 'SET IDENTITY_INSERT '+@TableName+' OFF'

調(diào)用時(shí) exec OutputData 'myuser' 其中myUser中當(dāng)前數(shù)據(jù)庫中存在的表。

另外方丈的:

drop proc proc_insert

go

create proc proc_insert (@tablename varchar(256))

as

begin

set nocount on

declare @sqlstr varchar(4000)

declare @sqlstr1 varchar(4000)

declare @sqlstr2 varchar(4000)

select @sqlstr='select ''insert '+@tablename

select @sqlstr1=''

select @sqlstr2=' ('

select @sqlstr1= ' values ( ''+'

select @sqlstr1=@sqlstr1+col+'+'',''+' ,@sqlstr2=@sqlstr2+name +',' from (select case

-- when a.xtype =173 then 'case when '+a.name+' is null then ''NULL'' else '+'convert(varchar('+convert(varchar(4),a.length*2+2)+'),'+a.name +')'+' end'

when a.xtype =104 then 'case when '+a.name+' is null then ''NULL'' else '+'convert(varchar(1),'+a.name +')'+' end'

when a.xtype =175 then 'case when '+a.name+' is null then ''NULL'' else '+'''''''''+'+'replace('+a.name+','''''''','''''''''''')' + '+'''''''''+' end'

when a.xtype =61 then 'case when '+a.name+' is null then ''NULL'' else '+'''''''''+'+'convert(varchar(23),'+a.name +',121)'+ '+'''''''''+' end'

when a.xtype =106 then 'case when '+a.name+' is null then ''NULL'' else '+'convert(varchar('+convert(varchar(4),a.xprec+2)+'),'+a.name +')'+' end'

when a.xtype =62 then 'case when '+a.name+' is null then ''NULL'' else '+'convert(varchar(23),'+a.name +',2)'+' end'

when a.xtype =56 then 'case when '+a.name+' is null then ''NULL'' else '+'convert(varchar(11),'+a.name +')'+' end'

when a.xtype =60 then 'case when '+a.name+' is null then ''NULL'' else '+'convert(varchar(22),'+a.name +')'+' end'

when a.xtype =239 then 'case when '+a.name+' is null then ''NULL'' else '+'''''''''+'+'replace('+a.name+','''''''','''''''''''')' + '+'''''''''+' end'

when a.xtype =108 then 'case when '+a.name+' is null then ''NULL'' else '+'convert(varchar('+convert(varchar(4),a.xprec+2)+'),'+a.name +')'+' end'

when a.xtype =231 then 'case when '+a.name+' is null then ''NULL'' else '+'''''''''+'+'replace('+a.name+','''''''','''''''''''')' + '+'''''''''+' end'

when a.xtype =59 then 'case when '+a.name+' is null then ''NULL'' else '+'convert(varchar(23),'+a.name +',2)'+' end'

when a.xtype =58 then 'case when '+a.name+' is null then ''NULL'' else '+'''''''''+'+'convert(varchar(23),'+a.name +',121)'+ '+'''''''''+' end'

when a.xtype =52 then 'case when '+a.name+' is null then ''NULL'' else '+'convert(varchar(12),'+a.name +')'+' end'

when a.xtype =122 then 'case when '+a.name+' is null then ''NULL'' else '+'convert(varchar(22),'+a.name +')'+' end'

when a.xtype =48 then 'case when '+a.name+' is null then ''NULL'' else '+'convert(varchar(6),'+a.name +')'+' end'

-- when a.xtype =165 then 'case when '+a.name+' is null then ''NULL'' else '+'convert(varchar('+convert(varchar(4),a.length*2+2)+'),'+a.name +')'+' end'

when a.xtype =167 then 'case when '+a.name+' is null then ''NULL'' else '+'''''''''+'+'replace('+a.name+','''''''','''''''''''')' + '+'''''''''+' end'

else '''NULL'''

end as col,a.colid,a.name

from syscolumns a where a.id = object_id(@tablename) and a.xtype <>189 and a.xtype <>34 and a.xtype <>35 and a.xtype <>36

)t order by colid

select @sqlstr=@sqlstr+left(@sqlstr2,len(@sqlstr2)-1)+') '+left(@sqlstr1,len(@sqlstr1)-3)+')'' from '+@tablename

-- print @sqlstr

exec( @sqlstr)

set nocount off

end

go

drop proc proc_insert

go

create proc proc_insert (@tablename varchar(256))

as

begin

set nocount on

declare @sqlstr varchar(4000)

declare @sqlstr1 varchar(4000)

declare @sqlstr2 varchar(4000)

select @sqlstr=select insert +@tablename

select @sqlstr1=

select @sqlstr2= (

select @sqlstr1= values ( +

select @sqlstr1=@sqlstr1+col++,+ ,@sqlstr2=@sqlstr2+name +, from (select case

-- when a.xtype =173 then case when +a.name+ is null then null else +convert(varchar(+convert(varchar(4),a.length*2+2)+),+a.name +)+ end

when a.xtype =104 then case when +a.name+ is null then null else +convert(varchar(1),+a.name +)+ end

when a.xtype =175 then case when +a.name+ is null then null else +++replace(+a.name+,,) + ++ end

when a.xtype =61 then case when +a.name+ is null then null else +++convert(varchar(23),+a.name +,121)+ ++ end

when a.xtype =106 then case when +a.name+ is null then null else +convert(varchar(+convert(varchar(4),a.xprec+2)+),+a.name +)+ end

when a.xtype =62 then case when +a.name+ is null then null else +convert(varchar(23),+a.name +,2)+ end

when a.xtype =56 then case when +a.name+ is null then null else +convert(varchar(11),+a.name +)+ end

when a.xtype =60 then case when +a.name+ is null then null else +convert(varchar(22),+a.name +)+ end

when a.xtype =239 then case when +a.name+ is null then null else +++replace(+a.name+,,) + ++ end

when a.xtype =108 then case when +a.name+ is null then null else +convert(varchar(+convert(varchar(4),a.xprec+2)+),+a.name +)+ end

when a.xtype =231 then case when +a.name+ is null then null else +++replace(+a.name+,,) + ++ end

when a.xtype =59 then case when +a.name+ is null then null else +convert(varchar(23),+a.name +,2)+ end

when a.xtype =58 then case when +a.name+ is null then null else +++convert(varchar(23),+a.name +,121)+ ++ end

when a.xtype =52 then case when +a.name+ is null then null else +convert(varchar(12),+a.name +)+ end

when a.xtype =122 then case when +a.name+ is null then null else +convert(varchar(22),+a.name +)+ end

when a.xtype =48 then case when +a.name+ is null then null else +convert(varchar(6),+a.name +)+ end

-- when a.xtype =165 then case when +a.name+ is null then null else +convert(varchar(+convert(varchar(4),a.length*2+2)+),+a.name +)+ end

when a.xtype =167 then case when +a.name+ is null then null else +++replace(+a.name+,,) + ++ end

else null

end as col,a.colid,a.name

from syscolumns a where a.id = object_id(@tablename) and a.xtype <>189 and a.xtype <>34 and a.xtype <>35 and a.xtype <>36

)t order by colid

select @sqlstr=@sqlstr+left(@sqlstr2,len(@sqlstr2)-1)+) +left(@sqlstr1,len(@sqlstr1)-3)+) from +@tablename

-- print @sqlstr

exec( @sqlstr)

set nocount off

end

go

---------------------------------------------------------------------------------------

小干部的:

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)

標(biāo)簽: Sql Server 數(shù)據(jù)庫
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
久久只有精品| 乱一区二区av| 看国产成人h片视频| 99香蕉国产精品偷在线观看| 亚洲国产精品精华液ab| 成人国产亚洲欧美成人综合网| 666欧美在线视频| 激情久久五月天| 欧美日韩国产大片| 国产又黄又大久久| 91精品国产欧美一区二区18| 免费成人美女在线观看.| 日本韩国一区二区三区| 日韩成人av影视| 色狠狠色狠狠综合| 免费av网站大全久久| 欧美日韩一区二区三区高清| 久久99精品久久久久| 欧美肥大bbwbbw高潮| 国产精品中文字幕日韩精品| 日韩欧美中文字幕制服| 国产盗摄一区二区| 2024国产精品视频| 91浏览器入口在线观看| 久久久精品免费免费| 91在线视频播放地址| 2021中文字幕一区亚洲| 97久久精品人人澡人人爽| 国产免费观看久久| av不卡在线看| 视频一区二区不卡| 欧美日韩一区不卡| 成人免费的视频| 国产日韩欧美不卡| 中文日韩欧美| 日日夜夜一区二区| 欧美视频精品在线观看| 福利一区在线观看| 国产日本欧美一区二区| 欧美亚洲不卡| 亚洲自拍欧美精品| 久久久久久网| 韩国v欧美v日本v亚洲v| 欧美不卡高清| 中文字幕一区二区三区精华液| 国产精品久久国产三级国电话系列 | 亚洲裸体xxx| 国产精品一区二区a| 久久精品国产精品亚洲综合| 日韩一区二区三区电影 | 美日韩黄色大片| 在线综合+亚洲+欧美中文字幕| 成人黄色网址在线观看| 国产精品欧美一级免费| 国产精品制服诱惑| 国模一区二区三区白浆| 久久精品亚洲国产奇米99| 伊人久久亚洲美女图片| 午夜影视日本亚洲欧洲精品| 在线播放91灌醉迷j高跟美女 | 香蕉久久夜色精品国产使用方法| 欧美色综合网站| 成人免费视频一区| 亚洲欧美电影一区二区| 欧美在线观看18| zzijzzij亚洲日本少妇熟睡| 中文字幕一区二区三区在线不卡 | 亚洲无线视频| 日日夜夜精品视频天天综合网| 日韩一级大片在线观看| 国产在线视频欧美一区二区三区| 日韩电影在线一区二区| 欧美成人在线直播| 在线观看成人av电影| 男女性色大片免费观看一区二区 | 91久久国产综合久久| 成人h动漫精品一区二| 亚洲欧美日韩在线| 欧美午夜影院一区| 欧美啪啪一区| 久久se精品一区精品二区| 国产农村妇女毛片精品久久麻豆 | 久久精品免费观看| 久久精品亚洲一区二区三区浴池 | 国产精品一区在线| 1000精品久久久久久久久| 欧美性xxxxx极品少妇| 欧美日韩在线一二三| 日韩av电影一区| 国产亚洲欧美一区在线观看| 久久久xxx| 91日韩在线专区| 日本美女视频一区二区| 国产精品天美传媒| 欧美性色黄大片手机版| 亚洲婷婷在线| 国产91丝袜在线观看| 亚洲gay无套男同| 国产亚洲欧美日韩在线一区| 欧洲亚洲国产日韩| 亚洲视频精品| 国产激情偷乱视频一区二区三区| 一区二区三区美女视频| 欧美mv日韩mv亚洲| 久久午夜视频| 欧美在线观看天堂一区二区三区| 日本女优在线视频一区二区| 国产精品国产馆在线真实露脸 | 国产日产精品一区二区三区四区的观看方式 | 日韩欧美视频一区| 久久久精品午夜少妇| av中文字幕一区| 免费人成精品欧美精品| 国产精品女主播在线观看| 制服视频三区第一页精品| 国产在线视频欧美一区二区三区| 韩国视频一区二区| 亚洲图片欧美综合| 国产拍欧美日韩视频二区| 8x8x8国产精品| 久久综合九色99| 亚洲黄色成人| 欧美一区成人| 成人污视频在线观看| 蜜桃精品视频在线观看| 亚洲欧美日韩国产成人精品影院 | 成人av第一页| 久久精品国产99国产精品| 亚洲自拍都市欧美小说| 欧美国产综合色视频| 日韩欧美一级二级| 欧美日韩第一区日日骚| 亚洲男女自偷自拍| 黄色成人在线网址| 色综合一个色综合亚洲| 国产99久久久国产精品免费看| 日本大胆欧美人术艺术动态| 一区二区三区日韩| 国产精品久久久久久久蜜臀| 久久众筹精品私拍模特| 91精品国产综合久久精品app| 色综合久久88色综合天天| 国产欧美日韩综合一区在线观看| 欧美chengren| 成人免费毛片aaaaa**| 国产麻豆精品95视频| 久久超碰97中文字幕| 天天影视涩香欲综合网 | 欧美日韩视频一区二区三区| 国产91丝袜在线观看| 国产一区欧美日韩| 精品一二三四在线| 日本不卡一区二区三区高清视频| 亚洲福利一区二区| 夜夜嗨av一区二区三区网页| 亚洲视频中文字幕| 亚洲国产精品黑人久久久 | 韩国女主播成人在线| 久久99精品一区二区三区| 日韩电影在线一区二区| 亚洲五码中文字幕| 亚洲综合在线电影| 夜夜嗨av一区二区三区中文字幕| 一区二区三区中文字幕精品精品| 亚洲欧洲精品一区二区三区 | 欧美午夜一区| 女同性一区二区三区人了人一| 99re66热这里只有精品3直播 | 欧美自拍偷拍午夜视频| 色88888久久久久久影院野外| 久久精品午夜| 玖玖精品视频| 91精品国产日韩91久久久久久| 欧美精品乱码久久久久久按摩| 久久精品123| 一本一本大道香蕉久在线精品| 欧美夫妻性生活| eeuss影院一区二区三区| 精品久久久久一区二区国产| 亚洲一区二区三区免费在线观看| 亚洲精品1区2区| 99香蕉国产精品偷在线观看| 亚洲一区区二区| 久久亚洲一区二区| 欧美视频完全免费看| 欧美精品日韩一区| 日韩视频一区二区| 久久久久久久久一| 国产精品电影院| 亚洲狠狠丁香婷婷综合久久久| 亚洲精品视频一区二区| 亚洲18色成人| 日本成人在线网站| 国内精品第一页| 粉嫩aⅴ一区二区三区四区| 成人av电影在线网| 欧美久久一区| 一区二区黄色| 一本大道综合伊人精品热热| 欧美日韩一区精品|