我知道用delphi的方法将文件变成流写到字段读时先用ADOBLOB属性读入字段值再写入临时目录的生成临时文件即可。
---------------------------------------------------------------
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,p_w_picpath列名 p_w_picpath)
go
insert 表名 values(1,0x)
insert 表名 values(2,0x)
go
--存
sp_textcopy '你的服务器名','sa','你的密码','库名','表名','p_w_picpath列名','c:\aa.doc','where 编号=1','I' --注意条件是 编号=1
go
--读
sp_textcopy '你的服务器名','sa','你的密码','库名','表名','p_w_picpath列名','c:\aa.doc','where 编号=1','O' --注意条件是 编号=1
go
---------------------------------------------------------------
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,p_w_picpath列名 p_w_picpath)
go
insert 表名 values(1,0x)
insert 表名 values(2,0x)
go
--存
sp_textcopy '你的服务器名','sa','你的密码','库名','表名','p_w_picpath列名','c:\aa.doc','where 编号=1','I' --注意条件是 编号=1
go
--读
sp_textcopy '你的服务器名','sa','你的密码','库名','表名','p_w_picpath列名','c:\aa.doc','where 编号=1','O' --注意条件是 编号=1
go
转载于:https://blog.51cto.com/sally/125439