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

标签 c# sql-server-2008 fonts

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

我有一个例子,我应该从 C# Winforms 应用程序插入字体并从 Java 应用程序获取此字体,目前我正在插入 Font.Name, Font.StyleFont.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/

相关文章:

Android 静态布局字体大小

c# - 将字体添加到 CSS 页面

c# - 以存储过程作为参数调用函数

sql-server - SQL Server 如何找出同一列中的两个日期之间的差异?

c# - 后台工作人员完成后,我想更改表单上的标签。我应该在哪里添加这段代码?

database - 如何在 SQL Server 2008 中优化存储以下 SQL 数据

sql - 在查询中合并两个表

fonts - 通过删除字形来缩小.OTF字体的大小

javascript - 在 JS-asp.net MVC 中使用@Url.Action

c# - 有没有办法获取传递给方法的参数数组?