• 存储过程导出sqlServer数据脚本


    CREATE PROCEDURE dbo.UspOutputData

    @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 -- 判断对象是否存在

    begin

    print 'The object not exists'

    return

    end

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

    if @objectname is null or charindex(@objectname,@tablename)=0 --此判断不严密

    begin

    print 'object not in current database'

    return

    end

    if OBJECTPROPERTY(@objectId,'IsTable') < > 1 -- 判断对象是否是table

    begin

    print 'The object is not table'

    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'

    declare syscolumns_cursor cursor

    for select c.name,c.xtype from syscolumns c where c.id=@objectid order by c.colid

    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 暂时不处理

    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 '''''''+'+@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'

    GO

    调用存储过程

    select * from t_user
    exec dbo.UspOutputData 'dbo.t_user'

    再全选‘结果’并保存为.sql脚本文件即可:

    代码
    insert dbo.t_user(stuName,stuPwd) values( 'user' , '123' )
    insert dbo.t_user(stuName,stuPwd) values( 'archie2010' , '456' )
    insert dbo.t_user(stuName,stuPwd) values( 'alex' , '456' )
    insert dbo.t_user(stuName,stuPwd) values( 'archie' , '456' )
    insert dbo.t_user(stuName,stuPwd) values( 'archie2010' , '789' )
  • 相关阅读:
    HLG 1522 子序列的和【队列的应用】
    POJ 3273 Monthly Expense【二分】
    HDU 4004 The Frog's Games 【二分】
    POJ 2001 Shortest Prefixes【第一棵字典树】
    POJ 2823 Sliding Window【单调对列经典题目】
    HDU 1969 Pie 【二分】
    POJ 3125 Printer Queue【暴力模拟】
    POJ 3250 Bad Hair Day【单调栈】
    字典树【模板】
    验证码 Code
  • 原文地址:https://www.cnblogs.com/archie2010/p/1918082.html
Copyright © 2020-2023  润新知