加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

使用PostgreSQL hstore for i18n

发布时间:2020-12-13 16:08:06 所属栏目:百科 来源:网络整理
导读:我只是为一个需要本地化支持的新项目建模PostgreSQL数据库.我想知道hstore是否可能是本地化某些数据字段的好方法. 例如:让我们使用post_title和post_content字段的博客文章的简化表格.使用键值类型hstore,可以向这些字段添加多个翻译,使用语言代码作为键标
我只是为一个需要本地化支持的新项目建模PostgreSQL数据库.我想知道hstore是否可能是本地化某些数据字段的好方法.

例如:让我们使用post_title和post_content字段的博客文章的简化表格.使用键值类型hstore,可以向这些字段添加多个翻译,使用语言代码作为键标识:

id | post_title (hstore)   | post_content (hstore)
---|-----------------------|------------------------------
 1 | "en" => "Hello World",| "en" => "Content in english",| "de" => "Hallo Welt"  | "de" => "Inhalt auf deutsch"
---|-----------------------|------------------------------
 2 | ...                   | ...

有没有人有这种方法的经验?它似乎非常灵活且易于使用,但也许我在这里缺少一些明显的缺点?

解决方法

我也在项目中使用这种方法,我相信这是一个很好的决定,因为我可以轻松地为我的项目添加一种新语言,而无需编写代码或更新数据库模式

此外,我可以轻松地将回退添加到这样的查询:

select coalesce(nullif(post_title -> :lang,''),post_title -> 'en') from posts

此外,还有大量的powerful sql functions可供您使用.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读