我想将大文件存储在 DB2 数据库中,并且我需要更多关于哪种技术最适合使用的信息,因为我是这个 IBM 产品的新手(仅以前使用 T-SQL 的经验)。
情况:
- 我正在使用 DB2 C-express 10.1(我不知道如何使用压缩功能,但可以肯定这个发行版没有得到它 - 这不是问题,如果它可以帮助我,我可以更改发行版。
操作系统 - 视窗 7
数据文件类型 - ms word/pdf/ppt(我认为它们将存储为二进制对象)
那么,对于我可以使用的最佳技术(谈论安全性和性能)有什么建议吗?
我想我正在寻找带有 BLOB 对象的 MS File-Stream Enable Database 之类的东西。
DB2 在存储大文件方面应该完全没有问题。您存储它们的一些方式将取决于您存储的具体内容。您是否存储 XML 文件?大文本文件?Word 文档还是 PDF?视频?声音的?
您有多种选择。图形字符串、二进制字符串、大对象(CLOB、BLOB 和 DBCLOB),以及纯 XML。
如果您只使用字符数据,我会支持
CLOB
. 但是请检查您的尺寸,如果您始终低于 32K,则使用VARCHAR
. (原因是 DB2 中的大对象默认存储在表之外(除非您使用该INLINE
选项,但即便如此,它也仅适用于特定大小的 LOB),并且它们也不缓存在缓冲池中。DB2 总是检索 LOB 的直接从磁盘(除非它们INLINE
如上所述)。如果您正在存储 XML 文档,您可能想要查看XML
类型,因为 DB2 有一种更优化的方式来存储和检索 XML。您可以在 XML 上设置特殊的 XML 索引类型也可以。您可以使用 SQL/XML 或使用 XPath 的 XQuery 查询 XML。如果您要存储二进制对象,那么我会选择
BLOB
.我认为您对压缩件的看法可能是正确的。(尽管测试它不会有什么坏处。DB2 中大约有四到五个不同的压缩级别,我知道我至少可以使用 9.7 Express-C 进行备份压缩)。
这是10.1版本的对比图。这是一篇关于不同版本以及它们所提供的内容的文章。
另请查看表格的空间要求,以帮助您更好地选择您需要的东西。