当前位置:首页 > 系统运维 > 正文内容

SQL Server存储图像数据大阅兵

a8116255316年前 (2010-07-23)系统运维12

文章描述的是SQL Server存储图像数据,我们大家都知道SQL Server数据库中的图像数据的存储机制在MIS SQL Server 数据库中,对于小于8000个字节的图像数据,其可以用二进制型(binary、varbinary)来表示。但通常要保存的一些医学影像图片都会大于 8000个字节。

SQL Server提供了一种机制,能存储每行大到 2G的二进制对象(BLOB),这类对象可包括image、text和ntext三种数据类型。Image数据类型存储的是二进制数据,更大长度是 231-1 (2,147,483,647)个字节[2][3]。

BLOB数据在MIS SQL Server存储图像数据系统中的存储方式不同于普通的数据类型,对于普通类型的数据系统直接在用户定义的字段上存储数据值,而对于BLOB类型数据,系统开辟新的存储页面来存放这些数据,表中BLOB类型数据字段存放的仅是一个16个字节的指针,该指针指向存放该条记录的BLOB数据的页面。

2、 SQL Server中图像数据的存取 在MIS SQL Server存储图像数据中,当数据小于 8000 个字节时,可以用普通的SQL操纵语句(SELECT、INSERT、UPDATE、DELETE)来完成对字段的操纵,当数据大于8000个字节时,SQL提供了 WRITETEXT 、READTEXT和UPDATETEXT这三个函数来读取和修改数据。

这三个函数的使用 *** 为: (1) WRITETEXT {table.column text_ptr}[WITH LOG] {data} table.column为表中的字段,text_ptr为一个16个字节的指针,data为要写的数据值。可 选参数WITH LOG表示是否要写入日志文件中。

例:

DECLARE @ptrval binary(16) --指针 SELECT @ptrval =   TEXTPTR(img_ct) FROM zy_ct WHERE id_ct = 20010101001 WRITETEXT zy_ct.img_ct @ptrval  0x024324142342134214213421421454353452341 (2) READTEXT {table.column text_ptr offset size} [HOLDLOCK] table.column  

为表中的字段,text_ptr为一个16个字节的指针,offset 为偏移量,即从 第几个字节开始读数据,size为要读的字节数,HOLDLOCK 为在读数据中是否充许其他用户 修改该数据。

例:

DECLARE @ptrval varbinary(16) SELECT @ptrval = TEXTPTR(img_ct)   FROM zy_ct WHERE id_ct = 20010101001 READTEXT zy_ct.img_ct @ptrval   1 25 (3) UPDATETEXT {table_name.dest_column_name dest_text_ptr}{NULL|insert_offset} { NULL |   delete_length}[WITH LOG][ inserted_data| {table_name.src_column_name src_text_ptr}] table_name.dest_column_name   

为要修改的text, ntext, 或 image字段;

dest_text_ptr为指向其的指针;insert_offset为偏移量,对于text和image为从 第几开始字节开始写,对于ntext为从第几个字符(双字节)开始写;delete_length 为从insert_offset开始删除delete_length长度的字节(符),为0时不删除,为NULL时 为删除从insert_offset开始到结束的所有数据。要插入的数据为 inserted_data为,也可 是表table_name的src_column_name字段中指针 src_text_ptr所指数据。

例: DECLARE @ptrval binary(16) SELECT @ptrval = TEXTPTR(img_ct) FROM zy_ct WHERE id_ct = 20010101001 UPDATETEXT zy_ct.img_ct @ptrval 16 0x54345 可以看出,这三个函数的使用比较复杂,虽然可以通过生成存贮过程来调用执行SQL Server存储图像数据,但有一个缺陷是在读取数据时,READTEXT函数读取的数据无法直接传递回前端应用程序。

3、 VB 6.0中图像数据的存取 VB 6.0 的ADO Field 对象提供了GetChunk *** 和appendChunk *** 来存取BLOB数据[1],这两个函数实质是通过API调用WRITETEXT 、READTEXT和UPDATETEXT这三个函数,简化了调用的 *** 。

(1)GetChunk 和AppendChunk *** 介绍 GetChunk *** 检索其部分或全部长二进制或字符数据[4]。GetChunk 调用返回的数据将赋给“变量”。假如 Size 大于剩余的数据,则 GetChunk 仅返回剩余的数据而无需用空白填充“变量”。假如字段为空,则 GetChunk *** 返回 Null。

每个后续的 GetChunk 调用将检索从前一次 GetChunk 调用停止处开始的数据。但是,假如从一个字段检索数据然后在当前记录中设置或读取另一个字段的值,ADO 将认为已从之一个字段中检索出数据。

假如在之一个字段上再次调用 GetChunk *** ,ADO 将把调用解释为新的 GetChunk 操作并从记录的起始处开始读取。Field 对象的之一个 AppendChunk 调用将数据写入字段,覆盖所有现有的数据,随后的 AppendChunk 调用则添加到现有数据。

由于系统资源总是有限的,假如一次读(存)取大量数据SQL Server存储图像数据,可能会引起服务器、客户机死机或是服务器的性能大大下降,因此使用这两个函数时,要将图像数据进行分段读写。

扫描二维码推送至手机访问。

版权声明:本文由2345好导航站长资讯发布,如需转载请注明出处。

本文链接:http://www.2345hao.cn/blog/index.php/post/22249.html

分享给朋友:

“SQL Server存储图像数据大阅兵” 的相关文章

windows 7系统如何设置休眠时不断网以便继续完成下载

windows 7系统如何设置休眠时不断网以便继续完成下载

在Windows 7系统的默认设置中,当Windows 7系统处于休眠状态时,会同时断网的。如此一来,无论你正在使用迅雷还是快车等下载工具,同样可以在休眠状态下继续完成下载,最大限度做到从身边的小事开始支持环保。下面我们就详细介绍操作步骤,帮助Windows 7系统用户实现这一节能目标。 首先需要...

如何设置Win 7通知栏重新显示电源按钮

如何设置Win 7通知栏重新显示电源按钮

有些使用本本的朋友可能会发现,右下角通知栏区域会无法显示电源按钮,导致在插上电源或者是使用电池的时候都无法进行区分。造成这种情况大部分都是因为使用了第三方修改过的系统版本或者对于系统优化过度,所以今天就来解决这个问题。 第一步:在开始菜单的搜索窗口输入“gpedit.msc”,进入组策略编辑器,依...

windows 7查看电脑近期使用情况确定有没有被他人使用

windows 7查看电脑近期使用情况确定有没有被他人使用

我一个朋友最近装装了Windows 7,他总感觉有人用了他的电脑,但是一直不确定,他想知道有没有人动用他的电脑,问我有没有办法 我说设置一下就行了: 启动Windows 7,在搜索栏中输入编辑组,马上就搜索到了编辑组策略,点击即可启动程序编辑组策略。依次展开组策略左侧树形列表的计算机配置/管理模...

Windows7截图出现黑屏导致截的图黑呼呼一片

Windows7截图出现黑屏导致截的图黑呼呼一片

最近一些Windows 7用户反馈说,自己在截屏的时候出现黑屏,导致自己截的图黑呼呼一片。这个问题该怎么解决?今天小编就为大家提供一个解决的方法。 步骤 1 在windows xp时代,很多用户都曾被视频截图后的“全黑图片”困扰。对此,在解决本地播放时出现的截图变黑问题,一般有两个方法可以用来解...

ubuntu14.04打开个几个应用窗口最小化后怎么切换呢?

ubuntu14.04打开个几个应用窗口最小化后怎么切换呢?

ubuntu14.04应用窗口列表在哪里?在ubuntu下打开个几个应用窗口最小化后怎么切换呢,应用窗口列表在哪里呢? 1、多打开几个chrome浏览器窗口。 2、然后都做最小化处理。 3、现在我们在桌面左边的面板上找到"左右两边有小白点"的chrome浏览器应用图标,这就是chr...

windows 7系统下Windows服务被流氓软件注册怎么办?Windows服务

windows 7系统下Windows服务被流氓软件注册怎么办?Windows服务

解决方法: 其实处理这些使用流氓软件,需要将相关的.exe文件删除,使它不能再运行,或者直接清除这个服务本身,使计算机重启的时候,它不会再启动。比如Hijackthis扫描,在扫描日志中,一般会把非Windows系统的服务以023的方式列出来,如下面这段: O23 - ...