原文: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页面读取并显示图片,而真正引用该图片时如下示例

<img src="picshow.aspx" width="500" height="300" />

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

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

方法一:利用MemoryStream 和System.Drawing.Image

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"];

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();

               

            }

        }

SQL Server中的Image数据类型的操作的更多相关文章

  1. 浅谈SQL Server中的三种物理连接操作

    简介 在SQL Server中,我们所常见的表与表之间的Inner Join,Outer Join都会被执行引擎根据所选的列,数据上是否有索引,所选数据的选择性转化为Loop Join,Merge J ...

  2. SQL Server中的三种物理连接操作

    来源:https://msdn.microsoft.com/zh-cn/library/dn144699.aspx 简介 在SQL Server中,我们所常见的表与表之间的Inner Join,Out ...

  3. 浅谈SQL Server中的三种物理连接操作(HASH JOIN MERGE JOIN NESTED LOOP)

    简介 在SQL Server中,我们所常见的表与表之间的Inner Join,Outer Join都会被执行引擎根据所选的列,数据上是否有索引,所选数据的选择性转化为Loop Join,Merge J ...

  4. 浅谈SQL Server中的三种物理连接操作(Nested Loop Join、Merge Join、Hash Join)

    简介 在SQL Server中,我们所常见的表与表之间的Inner Join,Outer Join都会被执行引擎根据所选的列,数据上是否有索引,所选数据的选择性转化为Loop Join,Merge J ...

  5. Sql Server中常见的数据类型

    转至http://www.cnblogs.com/andy_tigger/archive/2011/08/21/2147745.html bit    整型 bit数据类型是整型,其值只能是0.1或空 ...

  6. SQL Server 中使用数据类型表示小数

    在使用的时候发现一个问题,由于编程的习惯,当数据库中需要存储小数的时候,就想当然的使用了float类型,可结果太让人意外了. 数据库中存储了0.5没问题,当使用0.6的时候,得到的确是0.599999 ...

  7. 从TXT文本文档向Sql Server中批量导入数据

    下面我们通过以下的简单的SQL语句即可实现数据的批量导入,代码如下: Bulk insert id From 'G:\文档\test.txt' With ( fieldterminator=',', ...

  8. SQL Server 中对 FOR XML和FROM的转换处理

    在SQL Server中对XML的再操作转换: 方法1: --生成XML SELECT * FROM [T_BAS_预算科目] FOR XML PATH --把XML转成SQL表 declare @X ...

  9. sql server中对xml进行操作

    一.前言 SQL Server 2005 引入了一种称为 XML 的本机数据类型.用户可以创建这样的表,它在关系列之外还有一个或多个 XML 类型的列:此外,还允许带有变量和参数.为了更好地支持 XM ...

随机推荐

  1. Noi2011 : 智能车比赛

    假设S在T左边,那么只能往右或者上下走 f[i]表示S到i点的最短路 f[i]=min(f[j]+dis(i,j)(i能看到j)) 判断i能看到j就维护一个上凸壳和一个下凸壳 时间复杂度$O(n^2) ...

  2. MONO Jexus部署最佳体验

    根据我的测试和得到的反馈意见,目前几个月内开发跨平台的asp.net企业应用,应该在这个范围内进行:mono版本:3.2.8 (或3.2.7)Jexus版本:5.5.1(或5.5)MVC版本:1.2. ...

  3. 【TYVJ】1982 武器分配(费用流)

    http://tyvj.cn/Problem_Show.aspx?id=1982 一眼题.. 源向每个人连容量为1,费用为0的边. 每个人向一个中转节点na连容量1,费用0的边(你也可以不连,直接连后 ...

  4. ubuntu14.04美化

    首先我美化grub启动菜单背景和开关机背景,还有自动换壁纸.其它的美化日后再写博文. Grub启动菜单背景更换: 这个很简单,比以前的ubuntu和grub版本简单多了,直接将图片文件放到/boot/ ...

  5. 转:mysql中int、bigint、smallint 和 tinyint的区别与长度的含义

    bigint 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字).存储大小为 8 个字节. P.S. b ...

  6. 记save函数

    在写商品修改的代码的时候,我使用到了create()函数,也使用到了save函数.但是我从表单接受过来的数据,在添加语句的时候都没成功.代码如下 function upd($goods_id){ $g ...

  7. Html - 横版TH+TD

    通常可位于表格上方的搜索区域html <div class="panel panel-default"> <div class="panel-body& ...

  8. HDU 1025 Constructing Roads In JGShining's Kingdom(二维LIS)

    Constructing Roads In JGShining's Kingdom Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65 ...

  9. 【转】移动Web单页应用开发实践——页面结构化

    1. 前言 在开发面向现代智能手机的移动Web应用的时候,无法避免一个事实,就是需要开发单页应用(Single Page WebApp).对于不同的系统需求,单页应用的粒度会不同,可能是整个系统都使用 ...

  10. 在fortran下进行openmp并行计算编程

    最近写水动力的程序,体系太大,必须用并行才能算的动,无奈只好找了并行编程的资料学习了.我想我没有必要在博客里开一个什么并行编程的教程之类,因为网上到处都是,我就随手记点重要的笔记吧.这里主要是open ...