PHP涉及数据库内容的多语言设计如何实现?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了PHP涉及数据库内容的多语言设计如何实现?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2673字,纯文字阅读大概需要4分钟。
内容图文
请问有人做过么?(就类似APPLE的官网的内容多语言切换)能不能帮一下忙,谢谢了
回复讨论(解决方案)
做过的大家都是怎么实现的一般?用字段?切换数据库?切换表?还是别的什么?
表中字段加多?言。
例如:
sc_title, en_title, tc_title
多语言界面,还是多语言内容?
表中字段加多?言。
例如:
sc_title, en_title, tc_title
这个做法是很不靠谱的,增加语言难道要增加字段吗?
语言改变不改动数据库的做法
table: res (id, ...)
table: res_lang (id, res_id, 语言, 内容...)
增加语言难道要增加表吗?
增加表就不是改动数据库了吗?
语言改变不改动数据库的做法
table: res (id, ...)
table: res_lang (id, res_id, 语言, 内容...)
增加语言难道要增加表吗?
增加表就不是改动数据库了吗?
语言改变不改动数据库的做法
table: res (id, ...)
table: res_lang (id, res_id, 语言, 内容...)
这个用法不需要增加表,以上
不用加字段,也不用加标,这样设计表
我之前是这样做的:
CREATE TABLE `article` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `albumID` int(11) DEFAULT NULL, `category` mediumint(8) unsigned NOT NULL DEFAULT '0', `title` varchar(120) NOT NULL, `uid` int(10) unsigned NOT NULL DEFAULT '0', `description` mediumtext NOT NULL, `content` text NOT NULL, `puttime` int(10) unsigned NOT NULL DEFAULT '0', `listorder` int(10) unsigned NOT NULL DEFAULT '999', `lang` varchar(20) NOT NULL DEFAULT 'zh_cn', PRIMARY KEY (`id`), KEY `category` (`category`), KEY `lang` (`lang`) ) ENGINE=MyISAM AUTO_INCREMENT=5961 DEFAULT CHARSET=utf8
其中lang字段用来标识不同语言,所有语种的都保存到这个表
增加字段或增加表,都可以轻松的将不同语种的内容关联在一起
如果自认为巧妙的用记录来保存,结果只是徒劳的增加访问的开销
增加字段或增加表,都可以轻松的将不同语种的内容关联在一起
如果自认为巧妙的用记录来保存,结果只是徒劳的增加访问的开销
这类数据99%要存到缓存里,这查询能增加多少开销?
你难道只是界面是多语的吗?
德文的界面中出现一篇日文的文章给谁看?
增加字段或增加表,都可以轻松的将不同语种的内容关联在一起
如果自认为巧妙的用记录来保存,结果只是徒劳的增加访问的开销
这类数据99%要存到缓存里,这查询能增加多少开销?
你难道只是界面是多语的吗?
德文的界面中出现一篇日文的文章给谁看?
增加字段或增加表,都可以轻松的将不同语种的内容关联在一起
如果自认为巧妙的用记录来保存,结果只是徒劳的增加访问的开销
这类数据99%要存到缓存里,这查询能增加多少开销?
奇怪,文章就不能缓存了?
具体采取哪种方案,要看产品需求
尽可能的复用公共的数据
比如只需求标题和内容多语言,图片共用,那就拆字段
如果不同语言发布的新闻完全不同,就分别独立成一条记录
如果模型都不一样,就考虑分表了
额,在这统一回复了,谢谢大家帮忙
内容总结
以上是互联网集市为您收集整理的PHP涉及数据库内容的多语言设计如何实现?全部内容,希望文章能够帮你解决PHP涉及数据库内容的多语言设计如何实现?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。