读写入大对象到SqlServer数据库

public static void Main()
{
//写入大对象到SqlServer
FileStream fs = new FileStream("C:\\test.bmp",FileMode.OPen,FileAccess.Read);
BinaryReader br = new BinaryReader(fs);

SqlConnection conn = new SqlConnection("server=localhost;uid=sa;pwd=sa;database=northwind");

string cmdText = "UPDATE EMPLOYEES" +
"SET Photo=@image where EmployeeId=1";

SqlCommand cmd = new SqlCommand(cmdText,conn);
cmd.Parameters.Add("@image",SqlDbType.Image);

cmd.Parameters["@image"].Value = br.ReadBytes((int)br.BaseStream.Length);

conn.Open();
int i=cmd.ExecuteNoQuery();


//从SQL Server中读取大对象
string cmdtext = "SELECT employeeid,photo" +
" from employees where employeeid = 1";


SqlCommand cmd2 = new SqlCommand(cmdtext,conn);

FileStream rfs;
BinaryWriter rbw;

long numread;
long startIndex;
int buffSize=4096;
byte[] buff = new byte[buffSize];

conn.Open();
SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.SequentialAccess);

if(rdr.Read())
{
int empid = rdr.GetInt32(0);

fs = new FileStream("c:\\mypic.bmp",FileMode.OpenOrCreate,FileAccess.Write);
bw = new BinaryWrite(fs);

startIndex=0;

numread = rdr.GetBytes(1,startIndex,buff,0,buffSize);

while(numread==buffSize)
{
bw.Write(buff);
bw.Flush();
startIndex+=buffSize;
numread = rdr.GetBytes(1,startIndex,buff,buffSize);
}
bw.Write(buff);
bw.Flush();

bw.Close();
fs.Close();
}
rdr.Close();
conn.Close();

}
posted @ 2007-08-31 17:27 Robot·H 阅读(51) 评论(0)  编辑 收藏 网摘 所属分类: asp.Net2.0

标题  
姓名  
主页
Email (博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
Google站内搜索

China-pub 计算机图书网上专卖店!6.5万品种 2-8折!
近千种 9-95 新二手计算图书火热销售中!
开发者征途系统新作:《设计模式——基于C#的工程化实现及扩展》



相关文章:

相关链接: