设定数据库的一个字段为 二进制 字段,一个为字符串字段将图片转化为 二进制数据 ,存入数据库二进制字段 ,图片名 直接存入字符串字段读取的时候,从二进制字段里读出 二进制数据,存在一个临时文件夹里,以原来字符串字段里的名称命名, 然后就可以 对这个临时图片文件 执行任何操作了,注意,操作完后,要记得删除掉历史图片文件

解决方案 »

  1.   

    textcopy 补充
    方法:
    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)
    insert 表名 values(2,0x)
    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           本来就可以在命令行方式下用textcopy命令把文件导入db的,但要按照提示一条一条输入参数
    这个过程做了简化