在知道可以从不同环境 (Windows/Linux) 和语言 (Java/PHP/Python/C#) 访问该字体的情况下,在 SQL Server 数据库中插入字体的最佳方法是什么?
我有一个例子,我应该从 C# Winforms 应用程序插入字体并从 Java 应用程序获取此字体,目前我正在插入 Font.Name
, Font.Style
和 Font.Size
以及 Java,我使用 Font.Decode();
方法检索字体。
它在很多情况下都有效,但我认为最好将字体文件传输到数据库并通过关联自定义构造的字符串来识别从数据库获取字体文件 .ttf
字体及其关联文件。
例如:字体名称
、字体大小
和字体样式
+ 字体文件
,因为有时该字体是未安装或在另一个系统上具有不同的名称(字体在我的情况下非常重要)。
最佳答案
微软研究院有一篇非常好的论文,名为 To Blob or Not To Blob .
他们经过大量的性能测试和分析后的结论是:
如果您的图片或文档大小通常低于 256K,将它们存储在数据库 VARBINARY 列中会更有效
如果您的图片或文档大小通常超过 1 MB,将它们存储在文件系统中会更有效(并且使用 SQL Server 2008 的 FILESTREAM 属性,它们仍然处于事务控制之下并且是数据库的一部分)
在这两者之间,根据您的使用情况,这有点难以抉择
如果您决定将图片放入 SQL Server 表中,我强烈建议使用单独的表来存储这些图片 - 不要将员工照片存储在员工表中 - 将它们保存在单独的表中。这样,假设您并不总是需要选择员工照片作为查询的一部分,那么 Employee 表就可以保持精简、简洁且非常高效。
对于文件组,请查看Files and Filegroup Architecture进行介绍。基本上,您可以从一开始就为大型数据结构创建具有单独文件组的数据库,或者稍后添加其他文件组。我们将其称为“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 关于文件组的介绍,并尝试一下!
关于c# - 在 SQL Server 数据库中保存字体的最佳方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7484498/