LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

sql2005创建存储过程导出数据inset插入语句-如何导出数据

liguoquan
2023年3月29日 16:19 本文热度 453
:sql2005创建存储过程导出数据inset插入语句-如何导出数据



存储过程代码如下图:

create PROCEDURE [dbo].[Proc_Generateinsert]

@tablename SYSNAME,

@filter NVARCHAR(500),

@Order NVARCHAR(500)

AS

DECLARE @column VARCHAR(MAX)   

DECLARE @columndata VARCHAR(MAX)   

DECLARE @sql VARCHAR(MAX)   

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 + '[' + RTRIM(@name) +']'  

            

            SET @columndata = @columndata + CASE 

                                                 WHEN LEN(@columndata) = 0 THEN 

                                                      ''

                                                 ELSE ','','','

                                            END 

                

                + CASE 

                       WHEN @xtype IN (167, 175) THEN '''''''''+rtrim([' + @name

                            + '])+''''''''' --varchar,char

                       WHEN @xtype IN (231, 239) THEN '''''''''+rtrim([' + @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 '[' + RTRIM(@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 ''--'',' + RTRIM(@columndata) + ','')'' from ' + @tablename  

IF @filter IS NOT NULL

   AND LEN(RTRIM(@filter)) <> 0

    SET @sql = @sql + ' where ' + @filter  

IF @Order IS NOT NULL

   AND LEN(RTRIM(@Order)) <> 0

    SET @sql = @sql + ' Order By ' + @Order 

PRINT '--' + @sql   

exec (@sql)   

IF @ident IS NOT NULL

    PRINT 'SET IDENTITY_insert ' + @TableName + ' OFF'  

创建完后,执行存储过程,要输入三个变量,@tablename是表名,@filter是断点查询条件,接where后的条件,@Order是排序,按哪个字段排序,若全导,设为空即可

代码如下图:

exec Proc_Generateinsert @tablename='scm_bom_list',@filter='',@Order=''

执行完把结果复制出来执行即可

如下图:



该文章在 2023/3/29 16:19:59 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2024 ClickSun All Rights Reserved