sql image类型 java_SQL Server中的Image数据类型的操作

准备工作,在库Im_Test中建立一张表Im_Info,此表中有两个字段,分别为Pr_Id (INT),Pr_Info (IMAGE),用来存储图形编号及图形信息。其语法如下:

CREATE TEALE Im_Info (

Pr_Id INT NULL ,

Pr_Info IMAGE NULL

)

第一步: 往表中插入一条记录,并初始化PR_INFO字段。其语法如下:

INSERT INTO Im_Info VALUES (1 ,0xFFFFFFFF)

第二步往表中写入图形信息。其语法如下:

DECLARE @@ptrval varbinary(16)

SELECT @@ptrval = TEXTPTR(Pr_Info)

FROM Im_Info

WHERE Pr_Id = 1

WRITETEXT Im_Text.Im_Info

@@ptrval 0x624fd543fd…..

其中0x624fd543fd….. 为图形的十六进制数据,可以通过C 、Java等工具获得。

注意在写入图形信息前必须先将此数据库的 'select into/bulkcopy' 属性设置为 True ,其语法如下:

use master

exec sp_dboption Im_Test ,'select into/bulkcopy' ,True

C#读取Image数据类型:

(1)控制台应用程序下演示插入图片

public void InsertIMG()

{

//将需要存储的图片读取为数据流

FileStream fs = new FileStream(@"E:\c.jpg", FileMode.Open,FileAccess.Read);

Byte[] btye2 = new byte[fs.Length];

fs.Read(btye2 , 0, Convert.ToInt32(fs.Length));

fs.Close();

using (SqlConnection conn = new SqlConnection(sqlconnstr))

{

conn.Open();

SqlCommand cmd = new SqlCommand();

cmd.Connection = conn;

cmd.CommandText = "insert into T_Img(imgfile) values(@imgfile)";

SqlParameter par = new SqlParameter("@imgfile", SqlDbType.Image);

par.Value = bt;

cmd.Parameters.Add(par);

int t=(int)(cmd.ExecuteNonQuery());

if (t > 0)

{

Console.WriteLine("插入成功");

}

conn.Close();

}

}

(2)控制台应用程序下读出并生成图片到物理位置

public void Read()

{

byte[] MyData = new byte[0];

using (SqlConnection conn = new SqlConnection(sqlconnstr))

{

conn.Open();

SqlCommand cmd = new SqlCommand();

cmd.Connection = conn;

cmd.CommandText = "select * from T_img";

SqlDataReader sdr = cmd.ExecuteReader();

sdr.Read();

MyData = (byte[])sdr["ImgFile"];//读取第一个图片的位流

int ArraySize= MyData.GetUpperBound(0);//获得数据库中存储的位流数组的维度上限,用作读取流的上限

FileStream fs = new FileStream(@"c:\00.jpg", FileMode.OpenOrCreate, FileAccess.Write);

fs.Write(MyData, 0, ArraySize);

fs.Close();   //-- 写入到c:\00.jpg。

conn.Close();

Console.WriteLine("读取成功");//查看硬盘上的文件

}

}

(3)Web下picshow.aspx页将图片读取出来并写入到浏览器上呈现

public void Read()

{

byte[] MyData = new byte[0];

using (SqlConnection conn = new SqlConnection(sqlconnstr))

{

conn.Open();

SqlCommand cmd = new SqlCommand();

cmd.Connection = conn;

cmd.CommandText = "select * from T_img";

SqlDataReader sdr = cmd.ExecuteReader();

sdr.Read();

MyData = (byte[])sdr["ImgFile"];

Response.ContentType = "image/gif";

Response.BinaryWrite(MyData);

conn.Close();

Response.Write("读取成功");

}

(4)在web中可以如上picshow.aspx页面读取并显示图片,而真正引用该图片时如下示例

picshow.aspx

(5)Winform下将图片写入到sql数据库image类型字段中的方法和以上方法基本一致,仅区别于可以利用多个对话框来帮助选取存储图片等,各个属性可以方便的利用上

(6)Winform下读取图片在picturebox控件中显示出来

方法一:利用MemoryStream 和System.Drawing.Imagepublic void Read()

{

byte[] MyData = new byte[0];

using (SqlConnection conn = new SqlConnection(sqlconnstr))

{

conn.Open();

SqlCommand cmd = new SqlCommand();

cmd.Connection = conn;

cmd.CommandText = "select * from T_img";

SqlDataReader sdr = cmd.ExecuteReader();

sdr.Read();

MyData = (byte[])sdr["ImgFile"];

MemoryStream mystream = new MemoryStream(MyData);

//用指定的数据流来创建一个image图片

System.Drawing.Image img = System.Drawing.Image.FromStream(mystream, true);

System.Windows.Forms.PictureBox picbox = new PictureBox();

picbox.Image = img;

picbox.Left = 30;

picbox.Top = 80;

picbox.Width = 800;

picbox.Height = 500;

this.Controls.Add(picbox);

mystream.Close();

conn.Close();

}

}

方法二:将流直接读取成图片并写入到物理位置,然后再行利用该图片呈现

void Read()

{

using (SqlConnection conn = new SqlConnection(sqlconnstr))

{

conn.Open();

SqlCommand cmd = new SqlCommand();

cmd.Connection = conn;

cmd.CommandText = "select * from T_img";

SqlDataReader sdr = cmd.ExecuteReader();

sdr.Read();

byte[] Image_img = (byte[])sdr["ImgFile"];

if (Image_img.Length == 0)

{

return;

}

int filelength = Image_img.Length;

string imageName = "1.jpg";

string myUrl = Environment.CurrentDirectory + "\\" + imageName;

FileStream fs = new FileStream(myUrl, FileMode.OpenOrCreate,FileAccess.Write);

BinaryWriter BW = new BinaryWriter(fs);

BW.BaseStream.Write(Image_img, 0, filelength);

BW.Flush();

BW.Close();

System.Windows.Forms.PictureBox picbox = new PictureBox();

//为picbox添加图片方法一

//picbox.ImageLocation = myUrl;

//picbox.Width = 800;

//picbox.Height = 300;

//为picbox添加图片方法二

Bitmap bitmap = new Bitmap(myUrl);

picbox.Width = 100;//bitmap.Width;

picbox.Height = 80;//bitmap.Height;

picbox.Image = (Image)bitmap;

picbox.SizeMode = System.Windows.Forms.PictureBoxSizeMode.StretchImage;

picbox.Left = 20;

picbox.Top = 30;

this.Controls.Add(picbox);

conn.Close();

}

}

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值