mysql国际化存储方案

之前第一次做国际化项目,前期数据库是同事设计的,他的想法是,需要多语言的字段,全部用多个字段,如 name 存储中文姓名,english_name存储英文姓名,如果项目始终固定两种语言,这种设计完全没问题,但一旦需要新增语言,所有涉及到国际化的字段,全部要新增一个字段!

后来重新想了个方案,mysql5.7支持json数据类型,需要国际化的字段,全部使用json类型,存储的数据示例:

name字段需要国际化,使用json类型:

{
 "cn":"疼样",
 "en":"Teng yang",
 "other":"*……&¥#87"
}

//or

{
 "name_cn":"疼样",
 "name_en":"Teng yang",
 "name_other":"*……&¥#87"
}

后面公司新项目,涉及国际化的,会尝试使用这种方案,不确定会不会遇到什么坑,走着瞧,O(∩_∩)O哈哈~

最后来几条json类型sql操作:

CREATE TABLE `test` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` json DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
INSERT INTO `test` (`name`) VALUES ('{"cn":"疼样","en":"Teng yang","other":"*……&¥#87"}');
SELECT json_extract(`name`,'$.en') AS `name` FROM `test`;

SELECT `name` -> '$.zh' AS `name` FROM `test`;

SELECT * FROM test WHERE `name` -> '$.en' LIKE '%key%';
UPDATE `test` SET `name`=json_set(`name`,'$.en','Ty');

UPDATE `test` SET `name`='{"cn":"疼样","en":"TY","other":"no"}';

JSON数组查询:

SELECT JSON_EXTRACT(order_details ,'$[0]') AS roomName FROM test;

SELECT JSON_EXTRACT(order_details ,'$[0].roomName') AS roomName FROM test;

SELECT order_details -> '$[0].roomName' AS roomName FROM test;

-- 去 引号
SELECT order_details ->> '$[0].roomName' AS roomName FROM test;
SELECT JSON_UNQUOTE(order_details -> '$[0].roomName') FROM b_room_order

SELECT JSON_SEARCH('[1,2,3]','one', '1');

SELECT JSON_CONTAINS('[1,2,3]', '[1, 2]');

  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值