在SQL Server数据库中保存字体的最佳方法

本文关键字:字体 最佳 方法 保存 SQL Server 数据库 | 更新日期: 2023-09-27 18:09:20

在知道该字体可以从不同环境(Windows/Linux)和语言(Java/PHP/Python/c#)访问的情况下,在SQL Server数据库中插入字体的最佳方式是什么?

我有一个情况,我应该从c# Winforms应用程序中插入字体,并从Java应用程序中获取此字体,目前我正在插入Font.Name, Font.StyleFont.Size,并从Java中使用Font.Decode();方法检索字体。

它在许多情况下都有效,但我认为最好将字体文件传输到数据库,并通过关联一个自定义构造字符串来识别字体及其相关文件,从而从数据库中获取字体文件.ttf

例如:Font Name, Font SizeFont Style + Font File,因为有时该字体没有安装或在另一个系统上有不同的名称(字体在我的情况下非常重要)。

在SQL Server数据库中保存字体的最佳方法

微软研究院有一篇非常好的论文,叫做To Blob or Not To Blob。

经过大量的性能测试和分析,他们的结论是:

  • 如果您的图片或文档的大小通常低于256K,那么将它们存储在数据库VARBINARY列中会更有效

  • 如果你的图片或文档的大小通常超过1mb,将它们存储在文件系统中更有效(并且使用SQL Server 2008的FILESTREAM属性,它们仍然处于事务控制之下,并且是数据库的一部分)

  • 介于这两者之间,这取决于你的使用

如果你决定把你的照片放在一个SQL Server表中,我强烈建议使用一个单独的表来存储这些照片-不要将员工照片存储在员工表中-将它们保存在一个单独的表中。这样,Employee表可以保持精简和高效,假设您不总是需要选择员工照片作为查询的一部分。

对于文件组,请查看文件和文件组架构以获得介绍。基本上,您可以从一开始就使用单独的文件组为大型数据结构创建数据库,或者稍后添加额外的文件组。我们把它命名为"LARGE_DATA"。

现在,每当您要创建一个需要存储VARCHAR(MAX)或VARBINARY(MAX)列的新表时,您可以为大数据指定这个文件组:

 CREATE TABLE dbo.YourTable
     (....... define the fields here ......)
     ON Data                   -- the basic "Data" filegroup for the regular data
     TEXTIMAGE_ON LARGE_DATA   -- the filegroup for large chunks of data

查看MSDN关于文件组的介绍,并使用它!