SQL Server存储图像数据的策略与方法

SQL Server存储图像数据的策略与方法

ID:37898152

大小:39.00 KB

页数:5页

时间:2019-06-02

SQL Server存储图像数据的策略与方法_第1页
SQL Server存储图像数据的策略与方法_第2页
SQL Server存储图像数据的策略与方法_第3页
SQL Server存储图像数据的策略与方法_第4页
SQL Server存储图像数据的策略与方法_第5页
资源描述:

《SQL Server存储图像数据的策略与方法》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、SQLServer存储图像数据的策略与方法 目前对于图像数据的管理大都采用表+实体的方法,即图像数据以文件形式存放于指定的计算机目录下,在数据库表中只反映图像数据文件的存储路径。这种管理模式,给数据的维护增加了难度,同时,也给数据的安全带来一定的隐患。因此,要真正做到各类数据在数据库中安全管理,研究和探索直接将图像数据存储在数据库关系表中的方法是非常必要的。  笔者在VisualBasic6.0开发环境中,采用客户机/服务器的工作方式,针对SQLServer数据库关系表中存储图像数据的问题进行了初步探讨,提出了一套基本解决方案,供读者

2、参考。  一、存储图像数据的策略  图像数据库技术一直致力于解决海量数字图像的有效存储和管理问题。它是数据库技术的继承和发展,一方面,图像数据和文本数据存在着本质的区别,在文本数据领域得以成功应用的传统数据库技术,如果一成不变的照搬到图像数据库领域,结果往往是低效,甚至无效;另一方面,传统数据库的许多成果,如SQL语言、索引技术等都值得图像数据库借鉴。上述两个方面的结合成为目前图像数据库技术发展的主流。  1.1BLOB数据类型  BLOB是非常巨大的不定的二进制或者字符型数据,通常是文档(.txt、.doc)和图片(.jpeg、.g

3、if、.bmp),它可以存储在数据库中。在SQLServer中,BLOB可以是text、ntext或者image数据类型。Image数据类型存储的是长度不确定的二进制数据,最大长度是2GB。  BLOB数据在SQLServer系统中的存储方式不同于普通的数据类型,对于普通类型的数据系统直接在用户定义的字段上存储数据值,而对于BLOB类型数据,系统开辟新的存储页面来存放这些数据,表中BLOB类型数据字段存放的仅是一个16个字节的指针,该指针指向存放该条记录的BLOB数据的页面。1.2BLOB的设计策略  BLOB数据是数据量很大的数据类

4、型,它会占用大量的硬盘空间、内存和网络资源,因此合理地设计包含有BLOB数据类型的属性表,对提高存储效率、查询速度有很大的影响。一般BLOB的设计原则如下:  (1)使用BLOB数据类型还是使用varchar或者varbinary数据类型  二进制大对象并不一定要存储为text、ntext或者image数据类型,它们也可以作为varchar或者varbinary数据类型村处在表格中。数据类型的选择要根据将要存储的BLOB的实际大小。如果数据不会超过8K,那么就使用Varchar或者varbinary数据类型。如果这些大对象的尺寸超过8

5、K,那么就使用text、ntext或者image数据类型。  (2)存储BLOB在数据库中或者在文件系统中  常见的设计问题是将图片存在数据库中还是存在文件系统中。在大多数情况下,最好把图片文件与其它数据一起存在数据库中。因为将影像数据文件存储在数据库中有许多优点:  易于管理当BLOB与其他数据一起存储在数据库中时,BLOB和表格是数据一起备份和恢复。这样就降低了表格数据与BLOB数据不同步的机会,而且降低了其他用户无意中删除了文件系统中BLOB数据位置的路径和风险。另外,将数据存储在数据库中BLOB和其他数据的插入、更新和删除都在

6、同一个事务中实现。这样就确保了数据的一致性和文件与数据库之间的一致性。还有一点好处是不需要为文件系统中的文件单独设置安全性。  可伸缩性尽管文件系统被设计为能够处理大量不同大小的对象,但是文件系统不能对大量小文件进行优化。在这种情况下,数据库系统可以进行优化。  可用性数据库具有比文件系统更多的可用性。数据库复制允许在分布式环境中复制、分配和潜在的修改数据。在主系统失效的情况下,日志转移提供了保留数据库备用副本的方法。当然,在某些情况下,将图片存储在文件系统中将是更好的选择:  (1)使用图片的应用程序需要数据流性能,例如实时的视频重

7、现。  (2)象MicrosoftPhotoDraw或者AdobePhotoshop这样的应用程序经常访问BLOB,这些应用程序只知道怎样访问文件。  (3)需要使用一些NTFS文件系统中的特殊功能,例如远程存储。  二、存储图像数据的方法  1建立具有image宇段的SQLServer数据库  当需要在SQLServer数据库中存储图像数据时,首先应建立包含image数据类型字段的数据库关系表。SQLServer数据库平台支持的数据类型中,image数据类型主要用于存储图像数据等大段的二进制数据。SQLServer7.0之后的版本,

8、image类型可存储2GB的数据。  2使用RemoteData控件建立与数据库的连接  RemoteData控件是在VisualBasic应用程序中用来获取远程数据的控件。它在.远程数据对象(RDO)和数据绑定控件之间

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。