在数据库中放二进制文件的问题!!

    技术2022-05-11  110

    如果是存大文件的话,要用image类型(2,147,483,647字节), 因为binary  和  varbinary最大才能保存8000字节

    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

    create table Tab_Image (TID int,image列名 image)insert Tab_Image values(1,0x) -- 必须的,且不是nullselect * from Tab_Imagedelete from Tab_Imagesp_textcopy '127.0.0.1','sa','19790122','Temp','Tab_Image','T_image','c:/jbuilder_2005.bmp','where TID=1','O' --注意条件是 编号=1

    2、建表和初始化数据create table 表名 (编号 int,image列名 image)goinsert 表名 values(1,0x) -- 必须的,且不是nullinsert 表名 values(2,0x) -- 必须的,且不是nullgo

    3、读入sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:/图片.bmp','where 编号=1','I' --注意条件是 编号=1

    sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:/bb.doc','where 编号=2','I' --注意条件是 编号=2

    go

    4、读出成文件sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:/图片.bmp','where 编号=1','O' --注意条件是 编号=1

    sp_textcopy '你的服务器名','sa','你的密码','库名','表名','image列名','c:/bb.doc','where 编号=2','O' --注意条件是 编号=2go


    最新回复(0)