create PROCEDURE sp_textcopy (  
  @srvname    varchar (30),  
  @login      varchar (30),  
  @password    varchar (30),  
  @dbname      varchar (30),  
  @tbname      varchar (30),  
  @photoname    varchar (30),  
  @filename    varchar (30),  
  @whereclause varchar (40),  
  @direction  char(1))  
AS  
DECLARE @exec_str varchar (255)  
SELECT @exec_str =  
         'textcopy /S  ' + @srvname +  
         ' /U  ' + @login +  
         ' /P  ' + @password +  
         ' /D  ' + @dbname +  
         ' /T  ' + @tbname +  
         ' /C  ' + @photoname +  
         ' /W " ' + @whereclause +  
         '" /F  ' + @filename +  
         ' / ' + @direction  
EXEC master..xp_cmdshell @exec_str ,no_output  create table photo(id int identity(1,1),photo image,memo nvarchar(50) default  'my photo ') 
go 
insert photo(photo) values(0x)    -- 必须的,且不是null 
select * from photo 
--truncate table photo sp_textcopy  'roy ', 'sa ', 'wuxi ', 'test ', 'photo ', 'photo ', 'E:\photo\myphoto\roy3.jpg ', 'where id=5 ', 'I ' --注意条件是 id=1 
3、读入 
sp_textcopy  'roy ', 'sa ', 'wuxi ', 'test ', 'photo ', 'photo ', 'E:\photo\photo\21.jpg ', 'where id=1 ', 'I ' --注意条件是 id=1 sp_textcopy  'roy ', 'sa ', 'wuxi ', 'test ', 'photo ', 'photo ', 'E:\photo\photo\33.jpg ', 'where id=2 ', 'I ' --注意条件是 id=2 go 4、读出成文件 
sp_textcopy  'roy ', 'sa ', 'wuxi ', 'test ', 'photo ', 'photo ', 'E:\photo\roy.jpg ', 'where id=1 ', 'O ' --注意条件是 id=1 
sp_textcopy  'roy ', 'sa ', 'wuxi ', 'test ', 'photo ', 'photo ', 'E:\photo\roy1.jpg ', 'where id=2 ', 'O ' 
sp_textcopy  'roy ', 'sa ', 'wuxi ', 'test ', 'photo ', 'photo ', 'E:\photo\roy2.jpg ', 'where id=3 ', 'O ' 
sp_textcopy  'roy ', 'sa ', 'wuxi ', 'test ', 'photo ', 'photo ', 'E:\photo\roy3.jpg ', 'where id=4 ', 'O ' sp_textcopy  'roy ', 'sa ', 'wuxi ', 'test ', 'photo ', 'photo ', 'c:\bb.doc ', 'where id=5 ', 'O ' --注意条件是 id=2 

解决方案 »

  1.   

    用存储过程方法:
    1、建立过程
    CREATE PROCEDURE sp_textcopy ( 
      @srvname    varchar (30), 
      @login      varchar (30), 
      @password    varchar (30), 
      @dbname      varchar (30), 
      @tbname      varchar (30), 
      @colname    varchar (30), 
      @filename    varchar (30), 
      @whereclause varchar (40), 
      @direction  char(1)) 
    AS 
    DECLARE @exec_str varchar (255) 
    SELECT @exec_str = 
            'textcopy /S ' + @srvname + 
            ' /U ' + @login + 
            ' /P ' + @password + 
            ' /D ' + @dbname + 
            ' /T ' + @tbname + 
            ' /C ' + @colname + 
            ' /W "' + @whereclause + 
            '" /F ' + @filename + 
            ' /' + @direction 
    EXEC master..xp_cmdshell @exec_str  2、建表和初始化数据
    create table 表名 (编号 int,image列名 image)
    go
    insert 表名 values(1,0x)    -- 必须的,且不是null
    insert 表名 values(2,0x)    -- 必须的,且不是null
    go3、读入
    sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\图片.bmp','where 编号=1','I' --注意条件是 编号=1sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\bb.doc','where 编号=2','I' --注意条件是 编号=2go4、读出成文件
    sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\图片.bmp','where 编号=1','O' --注意条件是 编号=1sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:\bb.doc','where 编号=2','O' --注意条件是 编号=2
    go如果报textcopy不是可执行文件的话,你就到
    C:\Program Files\Microsoft SQL Server\MSSQL\Binn
    目录下拷备 textcopy.exe到:
    C:\Program Files\Microsoft SQL Server\80\Tools\Binn