Mat*_*idt 6 postgresql internationalization 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 | ... | ...
Run Code Online (Sandbox Code Playgroud)
有没有人有这种方法的经验?它似乎非常灵活且易于使用,但也许我在这里缺少一些明显的缺点?
我也在项目中使用这种方法,我相信这是一个很好的决定,因为我可以轻松地向我的项目添加新语言,而无需编写代码或更新数据库模式
我还可以轻松地为查询添加后备,如下所示:
select coalesce(nullif(post_title -> :lang, ''), post_title -> 'en') from posts
Run Code Online (Sandbox Code Playgroud)
另外,还有许多强大的 sql 函数可供您使用。
| 归档时间: |
|
| 查看次数: |
375 次 |
| 最近记录: |