积极答复者
SQL2000,SQL2005中怎样在表中插入Text,image数据

问题
答案
-
Text-- 直接用当字符串输入操作就行了
image--是SQL05之前的版本時使用的類型
直接操作,在SQL05以上版本用varbinary(max)--類型
以插入圖片為例:
SQL2000用 方法: 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 go 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' --注意条件是 编号=2 go ************如果报textcopy不是可执行文件的话,你就到 C:\Program Files\Microsoft SQL Server\MSSQL\Binn 目录下拷备 textcopy.exe到: C:\Program Files\Microsoft SQL Server\80\Tools\Binn SQL2005直接用 INSERT INTO myTable(FileName, FileType, Photo) SELECT 'Roy1.jpg' AS FileName, '.JPG' AS FileType, * FROM OPENROWSET(BULK N'C:\Roy1.jpg', SINGLE_BLOB) AS Document
ROY WU(吳熹 )- 已标记为答案 中國風MVP, Moderator 2010年2月25日 5:14
全部回复
-
你好,我明白你要的是什么
以图片为例子,看下面的代码
private void btnUpload_Click(object sender, System.EventArgs e)
{
SqlConnection con=new SqlConnection("server=.;database=pubs;uid=sa;pwd=;");
con.Open();
FileStream fs=File.Open(this.File1.PostedFile.FileName,FileMode.Open); //获得Post图片
byte[] by=new byte[fs.Length];
fs.Read(by,0,(int)fs.Length); //读到字节数组
String SqlCmd = "insert into ImageStore(ImageData,ImageContentType,ImageDescription,ImageSize) values(@Image,@fileType,@fileDec,@fileSize)";
SqlCommand CmdObj = new SqlCommand(SqlCmd, con);
CmdObj.Parameters.Add("@Image",SqlDbType.Image, (int)fs.Length).Value = by;
CmdObj.Parameters.Add("@fileType",SqlDbType.VarChar,20).Value=this.File1.PostedFile.ContentType;
CmdObj.Parameters.Add("@fileDec",SqlDbType.VarChar,200).Value=this.txtDescript.Text;
CmdObj.Parameters.Add("@fileSize",SqlDbType.BigInt).Value=this.File1.PostedFile.ContentLength;
fs.Close();
CmdObj.ExecuteNonQuery();
dataGridBind();
}
ImageData 的数据库类型是Image 类型的
希望对你有帮助
我们要把爱心传递给更多需要帮助的人。
微软(黑龙江).Net俱乐部:http://hlj.cnblogs.com
博客:http://terryfeng.cnblogs.com
微博:http://t.sina.com.cn/terryfeng
个人:http://www.terryfeng.com -
Text-- 直接用当字符串输入操作就行了
image--是SQL05之前的版本時使用的類型
直接操作,在SQL05以上版本用varbinary(max)--類型
以插入圖片為例:
SQL2000用 方法: 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 go 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' --注意条件是 编号=2 go ************如果报textcopy不是可执行文件的话,你就到 C:\Program Files\Microsoft SQL Server\MSSQL\Binn 目录下拷备 textcopy.exe到: C:\Program Files\Microsoft SQL Server\80\Tools\Binn SQL2005直接用 INSERT INTO myTable(FileName, FileType, Photo) SELECT 'Roy1.jpg' AS FileName, '.JPG' AS FileType, * FROM OPENROWSET(BULK N'C:\Roy1.jpg', SINGLE_BLOB) AS Document
ROY WU(吳熹 )- 已标记为答案 中國風MVP, Moderator 2010年2月25日 5:14