MyException - 我的异常网
当前位置:我的异常网» Sql Server » 多媒體資料庫的疑問,该如何解决

多媒體資料庫的疑問,该如何解决

www.myexceptions.net  网友分享于:2015-08-26  浏览:16次
多媒體資料庫的疑問
在下初學資料庫 工具是MS SQL 2008 跟VB.NET 目前有一個正想開發的項目

想問問各位前輩跟先進一些概念!

我去翻閱一些資料庫的書本,書本上說目前資料庫的領域已經成長開發到多媒體資料庫的功能,跟傳統上只能處理文字資料之別

有長足的進步。 所以想問問各位有開發過類似多媒體資料庫的前輩們幾個問題,就我所知多媒體資料庫可以建圖片跟聲音的資料庫功能

在MS SQL 2008有這個功能嗎? 我是想開發建立一個聲音的資料庫,目的用於智能回話的,所以應該是我把所有的聲音檔都儲存進聲音的資料庫

然後再用LINQ去調用聲音檔這樣對嗎? 想先了解這兩個概念,也希望前輩多多提供資訊。 感激不盡!

------解决方案--------------------
在MS SQL 2008有這個功能嗎? 我是想開發建立一個聲音的資料庫,目的用於智能回話的,所以應該是我把所有的聲音檔都儲存進聲音的資料庫

--------文件大小<256K建议放在数据库,读取速度比硬盘快,太大存放路径
------解决方案--------------------
BLOB类型文件,好像没有大小限制,ORACLE里是这样的,SQL不是很清楚了。
------解决方案--------------------
2008有个叫做filestream的功能 可以去查一下

但是在图片比较大的情况下 还是建议存储图片路径 在程序中调用路径


------解决方案--------------------
这里是联机丛书中关于 filestream 的介绍:

每天创建的大部分数据(如文本文档、图像和视频)均为非结构化的数据。这类非结构化的数据通常存储在数据库之外,以便与数据库中的结构化数据分隔开来。这种分隔可能会增加数据管理的复杂程度。或者,如果数据与结构化存储相关联,则可能会限制文件流功能和性能。

通过将 varbinary(max) 二进制大型对象 (BLOB) 数据以文件形式存储在文件系统上,FILESTREAM 使 SQL Server 数据库引擎和 NTFS 文件系统成为了一个整体。Transact-SQL 语句可以插入、更新、查询、搜索和备份 FILESTREAM 数据。通过 Win32 文件系统接口可以流式方式访问数据。

FILESTREAM 使用 NT 系统缓存来缓存文件数据。这有助于减少 FILESTREAM 数据可能对数据库引擎性能产生的任何影响。由于没有使用 SQL Server 缓冲池,因此该内存可用于查询处理。

何时使用 FILESTREAM
在 SQL Server 中,BLOB 可以是将数据存储在表中的标准 varbinary(max) 数据,也可以是将数据存储在文件系统中的 FILESTREAM varbinary(max) 对象。数据的大小和应用情况决定您应该使用数据库存储还是文件系统存储。如果满足以下条件,则应考虑使用 FILESTREAM:

所存储的对象平均大于 1 MB。


快速读取访问很重要。


您开发的是使用中间层作为应用程序逻辑的应用程序。


对于较小的对象,将 varbinary(max) BLOB 存储在数据库中通常会提供更为优异的流性能。

FILESTREAM 存储
FILESTREAM 存储以 varbinary(max) 列的形式实现,在该列中数据以 BLOB 的形式存储在文件系统中。BLOB 的大小仅受文件系统容量大小的限制。文件大小为 2 GB 的 varbinary(max) 标准限制不适用于存储在文件系统中的 BLOB。

若要指定列应将数据存储在文件系统中,请对 varbinary(max) 列指定 FILESTREAM 属性。这样数据库引擎会将该列的所有数据存储在文件系统,而不是数据库文件中。

FILESTREAM 数据必须存储在 FILESTREAM 文件组中。FILESTREAM 文件组是包含文件系统目录而非文件本身的专用文件组。这些文件系统目录称为“数据容器”。数据容器是数据库引擎存储与文件系统存储之间的接口。

使用 FILESTREAM 存储时,请考虑以下内容:

如果表包含 FILESTREAM 列,则每一行都必须具有唯一的行 ID。


不能嵌套 FILESTREAM 数据容器。


使用故障转移群集时,FILESTREAM 文件组必须位于共享磁盘资源上。


FILESTREAM 文件组可位于压缩卷上。

用于访问 BLOB 数据的双编程模型
在将数据存储在 FILESTREAM 列中之后,即可通过使用 Transact-SQL 事务或 Win32 API 访问文件。

Transact-SQL 访问
可以使用 Transact-SQL 来插入、更新和删除 FILESTREAM 数据:

您可以使用插入操作用 null 值、空值或相对较短的内联数据预填充 FILESTREAM 字段。但是,大量数据将以流的方式更有效地导入到使用 Win32 接口的文件中。


更新 FILESTREAM 字段时,即会修改文件系统中的基础 BLOB 数据。将 FILESTREAM 字段设置为 NULL 即会删除与该字段相关联的 BLOB 数据。您不能使用作为 UPDATE.Write() 实现的 Transact-SQL 成块更新以对数据执行部分更新。


当删除行或者删除或截断包含 FILESTREAM 数据的表时,将会删除文件系统中的基础 BLOB 数据。


文件系统流访问
在 SQL Server 事务上下文中支持 Win32 流。在事务之内,可以使用 FILESTREAM 函数来获取文件的逻辑 UNC 文件系统路径。接着使用 OpenSqlFilestream API 来获取文件句柄。然后 Win32 文件流接口(如 ReadFile() 和 WriteFile())可使用此句柄通过文件系统访问并更新文件。

由于文件操作属于事务操作,因此您无法通过文件系统删除或重命名 FILESTREAM 文件。

语句模型
FILESTREAM 文件系统访问通过使用文件打开和关闭来构建 Transact-SQL 语句模型。当打开文件句柄时,语句开始;当关闭句柄时,语句结束。例如,关闭写句柄时将激发表上注册的任何可能的 AFTER 触发器,就如 UPDATE 语句结束一样。

存储命名空间
在 FILESTREAM 中,数据库引擎控制 BLOB 物理文件系统的命名空间。PathName 是一个新增的内部函数,它提供对应于表中每个 FILESTREAM 单元的 BLOB 的逻辑 UNC 路径。应用程序使用此逻辑路径来获取 Win32 句柄并通过使用常见的 Win32 文件系统接口对 BLOB 数据进行操作。如果 FILESTREAM 列的值为 NULL,则此函数将返回 NULL。

事务文件系统访问
GET_FILESTREAM_TRANSACTION_CONTEXT() 是一个新增的内部函数,它提供表示与会话相关联的当前事物的标记。事务必须已启动,且仍未被中止或提交。通过获取标记,应用程序将 FILESTREAM 文件系统流操作与已启动的事务绑定在一起。在没有显式启动的事务的情况下,此函数将返回 NULL。

在提交或中止事务之前必须关闭所有文件句柄。如果在事务范围之外仍有句柄处于打开状态,则对句柄执行的其他读取将失败,对句柄执行的其他写入将成功,但实际数据不会写入磁盘中。与此类似,如果数据库或数据库引擎实例关闭,则所有处于打开状态的句柄均无效。

事务持久性
在事务提交时,数据库引擎通过使用 FILESTREAM 可确保通过文件系统流访问进行修改的 FILESTREAM BLOB 数据的事务持久性。

隔离语义
隔离语义由数据库引擎事务隔离级别决定。文件系统访问仅支持已提交读隔离级别。通过使用 Transact-SQL 访问 FILESTREAM 数据时,将支持重复的读取操作以及可序列化隔离和快照隔离。不支持脏读。

文章评论

代码女神横空出世
代码女神横空出世
什么才是优秀的用户界面设计
什么才是优秀的用户界面设计
60个开发者不容错过的免费资源库
60个开发者不容错过的免费资源库
程序员必看的十大电影
程序员必看的十大电影
10个帮程序员减压放松的网站
10个帮程序员减压放松的网站
我的丈夫是个程序员
我的丈夫是个程序员
“懒”出效率是程序员的美德
“懒”出效率是程序员的美德
总结2014中国互联网十大段子
总结2014中国互联网十大段子
程序员都该阅读的书
程序员都该阅读的书
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
我跳槽是因为他们的显示器更大
我跳槽是因为他们的显示器更大
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
旅行,写作,编程
旅行,写作,编程
程序员和编码员之间的区别
程序员和编码员之间的区别
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
2013年中国软件开发者薪资调查报告
2013年中国软件开发者薪资调查报告
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
为什么程序员都是夜猫子
为什么程序员都是夜猫子
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
老美怎么看待阿里赴美上市
老美怎么看待阿里赴美上市
不懂技术不要对懂技术的人说这很容易实现
不懂技术不要对懂技术的人说这很容易实现
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
程序猿的崛起——Growth Hacker
程序猿的崛起——Growth Hacker
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
Java程序员必看电影
Java程序员必看电影
我是如何打败拖延症的
我是如何打败拖延症的
做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
中美印日四国程序员比较
中美印日四国程序员比较
那些性感的让人尖叫的程序员
那些性感的让人尖叫的程序员
要嫁就嫁程序猿—钱多话少死的早
要嫁就嫁程序猿—钱多话少死的早
编程语言是女人
编程语言是女人
一个程序员的时间管理
一个程序员的时间管理
老程序员的下场
老程序员的下场
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
那些争议最大的编程观点
那些争议最大的编程观点
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
10个调试和排错的小建议
10个调试和排错的小建议
每天工作4小时的程序员
每天工作4小时的程序员
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
如何成为一名黑客
如何成为一名黑客
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
程序员的鄙视链
程序员的鄙视链
程序员应该关注的一些事儿
程序员应该关注的一些事儿
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有