我们使用资源文件(.resx)将我们的.NET 4.5 MVC C#应用程序翻译成不同的语言.这适用于位于视图中的静态文本.但是,我们从sql数据库中提取的值也需要转换.
示例:下拉列表,其中包含从数据库中的表填充的值.
在数据库中翻译这些值的最佳做法是什么?
解决方法
我设计的最后一个多语言应用程序我使用了一个表语言,对于每个有任何字符串类型的表(char,varchar etc`),我都有一个转换表.
这些方面的东西:
CREATE TABLE TblLanguage ( Language_Id int identity(1,1) PRIMARY KEY,Language_EnglishName varchar(30),Language_NativeName nvarchar(30),CONSTRAINT UC_TblLanguage UNIQUE(Language_EnglishName) ) CREATE TABLE TblSomeData ( SomeData_Id int identity(1,SomeData_TextColumn varchar(50),.... ) CREATE TABLE TblSomeData_T ( -- _T stands for translation SomeData_T_SomeData_Id int FOREIGN KEY TblSomeData(SomeData_Id),SomeData_T_Language_Id int FOREIGN KEY TblLanguage (Language_Id),SomeData_T_TextColumn nvarchar(100),PRIMARY KEY (SomeData_T_SomeData_Id,SomeData_T_Language_Id) )
我的应用程序使用英语作为默认(或主要)语言,因此我将默认语言保留在基表中,只保留转换表上的翻译.当然,如果您愿意,您可以仅在翻译表中保留字符串值.请注意,这不会考虑每种文化的不同日期和数字格式,这是在表示层上完成的.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。