关闭 x
IT技术网
    技 采 号
    ITJS.cn - 技术改变世界
    • 实用工具
    • 菜鸟教程
    IT采购网 中国存储网 科技号 CIO智库

    IT技术网

    IT采购网
    • 首页
    • 行业资讯
    • 系统运维
      • 操作系统
        • Windows
        • Linux
        • Mac OS
      • 数据库
        • MySQL
        • Oracle
        • SQL Server
      • 网站建设
    • 人工智能
    • 半导体芯片
    • 笔记本电脑
    • 智能手机
    • 智能汽车
    • 编程语言
    IT技术网 - ITJS.CN
    首页 » SQL Server »SQL Server对图像数据的存储机制介绍(1)

    SQL Server对图像数据的存储机制介绍(1)

    2015-11-29 00:00:00 出处:ITJS
    分享

    在一个完善的医院信息MIS中,图像数据的存取是必不可少的,比如X光片、CT像片的保存。一方面,这些图像数据在远程诊疗为准确诊断病情提供了重要的依据,另一方面,也为快速查阅病人资料提供了基本条件。图像数据的存取在其它应用系统如GIS中也有广泛的应用。

    1、SQL Server中图像数据的存储机制

    在MIS SQL Server 中,对于小于 8000 个字节的图像数据可以用二进制型(binary、varbinary)来表示。但通常要保存的一些医学影像图片都会大于 8000个字节。SQL Server提供了一种机制,能存储每行大到 2GB的二进制对象(BLOB),这类对象可包括image、text和ntext三种数据类型。Image数据类型存储的是二进制数据,最大长度是 231-1 (2,147,483,647)个字节。

    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)  --指针

    (2)程序实现

    程序一:写数据函数

    Public Function AppendBlobFromFile

    在一个完善的医院信息MIS中,图像数据的存取是必不可少的,比如X光片、CT像片的保存。一方面,这些图像数据在远程诊疗为准确诊断病情提供了重要的依据,另一方面,也为快速查阅病人资料提供了基本条件。图像数据的存取在其它应用系统如GIS中也有广泛的应用。

    1、SQL Server中图像数据的存储机制

    在MIS SQL Server 中,对于小于 8000 个字节的图像数据可以用二进制型(binary、varbinary)来表示。但通常要保存的一些医学影像图片都会大于 8000个字节。SQL Server提供了一种机制,能存储每行大到 2GB的二进制对象(BLOB),这类对象可包括image、text和ntext三种数据类型。Image数据类型存储的是二进制数据,最大长度是 231-1 (2,147,483,647)个字节。

    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

    可以看出,这三个函数的使用比较复杂,虽然可以通过生成存贮过程来调用执行,但有一个缺陷是在读取数据时,READTEXT函数读取的数据无法直接传递回前端应用程序。

    3、VB 6.0中图像数据的存取

    VB 6.0 的ADO Field 对象提供了GetChunk 方法和AppendChunk 方法来存取BLOB数据,这两个函数实质是通过API调用WRITETEXT 、READTEXT和UPDATETEXT这三个函数,简化了调用的方法。

    (1)GetChunk 和AppendChunk方法介绍

    GetChunk 方法检索其部分或全部长二进制或字符数据。GetChunk 调用返回的数据将赋给“变量”。假如 Size 大于剩余的数据,则 GetChunk 仅返回剩余的数据而无需用空白填充“变量”。假如字段为空,则 GetChunk 方法返回 Null。每个后续的 GetChunk 调用将检索从前一次 GetChunk 调用停止处开始的数据。但是,假如从一个字段检索数据然后在当前记录中设置或读取另一个字段的值,ADO 将认为已从第一个字段中检索出数据。假如在第一个字段上再次调用 GetChunk 方法,ADO 将把调用解释为新的 GetChunk 操作并从记录的起始处开始读取。Field 对象的第一个 AppendChunk 调用将数据写入字段,覆盖所有现有的数据,随后的 AppendChunk 调用则添加到现有数据。

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

    (2)程序实现

    程序一:写数据函数

    Public Function AppendBlobFromFile
    (blobColumn As ADODB.Field, ByVal FileName) As Boolean
    Dim FileNumber     As Integer     '文件号
               Dim DataLen             As Long            '文件长度
    Dim Chunks               As Long            '数据块数
    Dim ChunkAry()     As Byte     '数据块数组
    Dim ChunkSize      As Long            '数据块大小
    Dim Fragment       As Long            '零碎数据大小
    Dim lngI                   As Long  '计数器
     
    On Error GoTo ErrorHandle
    AppendBlobFromFile = False
    ChunkSize = 2048                          '限制每次读取的块大小为 2K
     
    FileNumber = FreeFile                        '产生随机的文件号
    Open FileName For Binary Access Read As FileNumber     '打开图像文件
    DataLen = LOF(FileNumber)               '获得文件长度
          If IsNull(blobColumn) Then Exit Function
     
    If DataLen = 0 Then                      '文件长度为0
    Close FileNumber
      AppendBlobFromFile = True
      Exit Function
    End If
          
    Chunks = DataLen ChunkSize           '数据块的个数
    Fragment = DataLen Mod ChunkSize
    If Fragment > 0 Then                    '先写零碎数据
    ReDim ChunkAry(Fragment - 1)
      Get FileNumber, , ChunkAry()          '读出文件
      blobColumn.AppendChunk ChunkAry   '调用AppendChunk函数写数据
    End If
       
    ReDim ChunkAry(ChunkSize - 1)        '为数据块开辟空间
    For lngI = 1 To Chunks                        '循环读出所有数据块
      Get FileNumber, , ChunkAry()          '读出一块数据
      blobColumn.AppendChunk ChunkAry '在数据库中增加数据块
    Next lngI
       
    Close FileNumber                   '关闭文件
    AppendBlobFromFile = True
    Exit Function
    ErrorHandle:
    AppendBlobFromFile = False
    MsgBox Err.Description, vbCritical, "写图像数据出错!"
    End Function

    程序二:读数据函数

    Public Function ReadbolbToFile
    (blobColumn As ADODB.Field, ByVal FileName) As Boolean
    Dim FileNumber     As Integer     '文件号
    Dim DataLen               As Long            '文件长度
    Dim Chunks               As Long            '数据块数
    Dim ChunkAry()     As Byte     '数据块数组
    Dim ChunkSize      As Long            '数据块大小
    Dim Fragment       As Long            '零碎数据大小
    Dim lngI                   As Long  '计数器
       
               On Error GoTo ErrorHandle
               ReadbolbToFile= False
               ChunkSize = 2048                        '定义块大小为 2K
               If IsNull(blobColumn) Then Exit Function
       
               DataLen = blobColumn.ActualSize           '获得图像大小
               If DataLen < 8 Then  Exit Function    '图像大小小于8字节时认为不是图像信息
                   FileNumber = FreeFile                      '产生随机的文件号
               Open FileName For Binary Access Write As FileNumber  '打开存放图像数据文件
               Chunks = DataLen ChunkSize         '数据块数
               Fragment = DataLen Mod ChunkSize   '零碎数据
               If Fragment > 0 Then                  '有零碎数据,则先读该数据
                          ReDim ChunkAry(Fragment - 1)
                          ChunkAry = blobColumn.GetChunk(Fragment)
                          Put FileNumber, , ChunkAry       '写入文件
               End If
       
               ReDim ChunkAry(ChunkSize - 1)             '为数据块重新开辟空间
               For lngI = 1 To Chunks                               '­循环读出所有块
               ChunkAry = blobColumn.GetChunk(ChunkSize)   '在数据库中连续读数据块
                          Put FileNumber, , ChunkAry()     '将数据块写入文件中
               Next lngI
               Close FileNumber                 '关闭文件
               ReadbolbToFile= True
               Exit Function
    ErrorHandle:
               ReadbolbToFile= False
               MsgBox Err.Description, vbCritical, "读图像数据出错!"
    End Function

    当BLOB类型的字段为空时,调用AppendChunk或 GetChunk函数将出错。此时假如想给该字段插入图像数据,应该先使用 Update语句给该字段赋初值如0x0,以便数据库系统为该字段分配一个页面地址来存放BLOB数据。

    4、总结

    Microsoft SQL Server为保存大二进制数据提供了存储平台,Visual Basic 6.0为存取这种数据提供了灵活的接口。本文介绍的用VB接口存取 MIS SQL Server中大二进制数据的方法,不但适用于图像文件,同样适用于其它类型的文件。该方法应用于医院管理系统的图像存取中,在存取速度、对系统的性能影响等方面都取了满意的效果。

    上一篇返回首页 下一篇

    声明: 此文观点不代表本站立场;转载务必保留本文链接;版权疑问请联系我们。

    别人在看

    Edge浏览器百度被劫持/篡改怎么办,地址后边跟着尾巴#tn=68018901_7_oem_dg

    Google Chrome 在 iPhone 上新增了 Safari 数据导入选项

    Windows 11专业版 KMS工具激活产品密钥的方法

    DEDECMS安全策略官方出品

    Microsoft Text Input Application 可以关闭吗?

    新版本QQ如何关闭自带的浏览器?

    C++编程语言中continue的用法和功能,附举例示范代码

    c++ map 的数据结构、基本操作以及其在实际应用中的使用。

    C语言如何避免内存泄漏、缓冲区溢出、空指针解引用等常见的安全问题

    C语言中的break语句详解

    IT头条

    马斯克2026最新采访总结:2040年,全球机器人数量将突破100亿台

    23:52

    专家解读|规范人工智能前沿业态健康发展的新探索:解读《人工智能拟人化互动服务管理暂行办法》

    00:54

    用至强 6高存力搞定MoE卸载!

    17:53

    美国将允许英伟达向中国“经批准的客户”出售H200 GPU

    02:08

    苹果与微信就15%手续费达成一致?腾讯未置可否

    22:00

    技术热点

    PHP 和 Node.js 的10项对比挑战

    Javascript闭包深入解析及实现方法

    windows 7、windows 8.1手动增加右键菜单功能技巧

    MYSQL出错代码大汇总

    windows 7假死机怎么办 windows 7系统假死机的原因以及解决方法

    Ubuntu(Linux)下配置IP地址的方法

      友情链接:
    • IT采购网
    • 科技号
    • 中国存储网
    • 存储网
    • 半导体联盟
    • 医疗软件网
    • 软件中国
    • ITbrand
    • 采购中国
    • CIO智库
    • 考研题库
    • 法务网
    • AI工具网
    • 电子芯片网
    • 安全库
    • 隐私保护
    • 版权申明
    • 联系我们
    IT技术网 版权所有 © 2020-2025,京ICP备14047533号-20,Power by OK设计网

    在上方输入关键词后,回车键 开始搜索。Esc键 取消该搜索窗口。