mysql多语言运营设计,mysql – 数据库设计:如何支持多语言网站?

假设我有桌子:

TABLE: product

=================================================================

| product_id | name | description |

=================================================================

| 1 | Widget 1 | Really nice widget. Buy it now! |

-----------------------------------------------------------------

如果我想提供多语言支持,那么最好的方法是什么?

可能的解决方案:

>在上表中添加“语言”列;这将表明特定记录的语言. (我不认为这是我的选择,因为其他表将使用product.product_id作为其FK.)

>删除产品表中的任何可翻译列(在上面的示例中,product.name和product.description),并将其放在带有“language”列的单独表中.该新表将使用product.product_id作为FK. (我不会在我的应用程序的第一个版本中支持多语言.这个解决方案意味着我必须做一个额外的JOIN才能获得最初支持的语言的值.)

>我没有考虑的其他事情?

解决方法:

我会选择解决方案2.

此选项将最小化您的第一个版本的工作,并将减少不更改的列之间的重复.

它确实需要一个额外的JOIN,但它是一个简单的键连接,所以它不会对你的性能产生太大影响.

标签:mysql,database-design,database,data-modeling

来源: https://codeday.me/bug/20190723/1516482.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值