利用SQL Server存储过程读数据写文件

数据库 SQL Server
SQL Server数据库中的存储过程用的比较多,下文介绍了一个利用SQL Server存储过程读数据写文件的实现方法,供您参考。

下面为您介绍的这个SQL Server存储过程,实现功能是将表内每两人之间相互通信内容区分开来,并分别写入文件,希望对您学习SQL Server存储过程方面能有所帮助。

--主过程(查找数据,并分类写入文件)

  1. CREATE PROC creatFileByNameProc  
  2. @filepath   varchar(128)  
  3. as   
  4. begin   
  5. declare  
  6. @fulFileName nvarchar(256),  
  7. @content nvarchar(2000),  
  8. @root nvarchar(64),  
  9. @str2 nvarchar(64),  
  10. @str3 nvarchar(64),  
  11. @target nvarchar(64),  
  12. @str5 nvarchar(64),  
  13. @str6 nvarchar(64),  
  14. @str7 nvarchar(64),  
  15. @str8 nvarchar(64) 

--文件是否存在的判断参数

  1. declare @isExist int, @filename1 nvarchar(256),@filename2 nvarchar(256) 

--文件操作参数

  1. declare   @obj   int   
  2. exec   sp_oacreate   'Scripting.FileSystemObject',@obj   out   
  3.  
  4. Declare MyCursor Cursor Scroll  
  5.       For Select [1],[2],[3],[4],[5],[6],[7],[8] From dbo.[1111] order by [7]  
  6. Open MyCursor  
  7.  
  8.  
  9. FETCH first from MyCursor into @root,@str2,@str3,@target,@str5,@str6,@str7,@str8  
  10. while @@fetch_status=0 
  11. Begin  
  12.             set @content= @root+'   '+@str2+'   '+@str3+'   '+@target+'   '+@str5+'   '+@str6+'   '+@str7+'   '+@str8  
  13. --print @content  
  14.             set @filename1= @target+'_'+ @root+'.txt'   
  15.             set @filename2= @root+'_'+@target+'.txt'   
  16.             set @isExist=   dbo.[FileExist]( @filepath +'\' , @filename1)  
  17. --- print @isExist  
  18.              if(@isExist=1)  
  19.                 begin  
  20.                   set @fulFileName=@filepath+'\'+@filename1  
  21. --print @fulFileName+'---1111111'  
  22.                   exec   p_movefile   @fulFileName,@content,@obj  
  23.           end   
  24.              else  
  25.                 begin  
  26.                   set @fulFileName=@filepath+'\'+@filename2  
  27. --print @fulFileName+'---22222'  
  28.                   exec   p_movefile @fulFileName,@content,@obj   
  29.                  end               
  30.  
  31. FETCH next from MyCursor into @root,@str2,@str3,@target,@str5,@str6,@str7,@str8  
  32. END  
  33. CLOSE MyCursor  
  34. DEALLOCATE MyCursor  
  35. end  

--判断文件是否存在的函数

  1. create function dbo.FileExist(  
  2. @filePath nvarchar(600),  
  3. @fileName nvarchar(400)  
  4. ) returns int  
  5. as  
  6. begin  
  7.  
  8. declare @result int  
  9. declare @sql nvarchar(1000)  
  10. set @sql=@filePath+@fileName  
  11.  
  12. exec master.dbo.xp_fileexist @sql,@result output   
  13. return @result  
  14. end  

--文件不存在,创建文件,写入内容;文件存在,追加内容

  1. create   proc   p_movefile     
  2. @filename   varchar(1000),--要操作的文本文件名     
  3. @text   varchar(8000),   --要写入的内容   
  4. @obj int   
  5. as     
  6. begin  
  7.  
  8. declare   @err   int,@src   varchar(255),@desc   varchar(255)     
  9.       
  10. exec   @err=sp_oamethod   @obj,'OpenTextFile',@obj   out,@filename,8,1     
  11. if   @err<>0   goto   lberr     
  12.       
  13. exec   @err=sp_oamethod   @obj,'WriteLine',null,@text     
  14. if   @err<>0   goto   lberr     
  15.       
  16. exec   @err=sp_oadestroy   @obj     
  17. return     
  18.       
  19. lberr:     
  20. exec   sp_oageterrorinfo   0,@src   out,@desc   out     
  21. select   cast(@err   as   varbinary(4))   as   错误号     
  22. ,@src   as   错误源,@desc   as   错误描述  
  23.  
  24. end   

--执行语句。(由于没有进行文件夹是否存在的处理,执行前需要指定好已存在路径)

  1. exec creatFileByNameProc 'E:\aa' 

 

 

 

 

【编辑推荐】

sql server系统表说明

SQL Server创建分区函数的方法

SQL SERVER全文检索的实现

带您了解SQL Server触发器的优点

SQL Server备份恢复的两种方法

责任编辑:段燃 来源: 互联网
相关推荐

2009-08-06 16:44:06

2010-09-14 10:47:45

sql server存

2010-07-15 12:38:14

SQL Server存

2011-03-28 10:46:36

sql server存储分页

2010-09-14 10:36:23

sql server存

2011-03-24 13:38:47

SQL Server 存储分页

2010-09-14 10:16:57

sql server

2010-11-12 09:46:55

Sql Server存

2011-08-15 15:14:54

SQL Server存储过程异常处理

2011-07-13 16:19:54

存储过程SQL Server数

2010-06-28 09:21:04

SQL Server存

2010-07-06 14:06:52

SQL Server存

2010-07-05 10:06:51

SQL Server扩

2010-11-10 13:03:15

SQL Server存

2011-07-28 14:31:47

SQL Server数存储过程

2010-04-16 13:53:23

Oracle数据库

2011-08-29 10:55:03

SQL Server分页存储过程优化效率分

2010-09-06 11:05:05

SQL SERVER语句

2010-07-09 10:48:02

SQL Server存

2010-07-01 13:42:58

SQL Server存
点赞
收藏

51CTO技术栈公众号