我必须从数据库中获取 i18n 文本。默认语言是英语,它包含所有内容的文本。但非英语语言不一定有所有所需的翻译。如果数据库中没有某个实体/键的非英语翻译,那么我希望它返回英文文本。所以,英语是这里的后备语言。
i18n 文本表如下所示(PostgreSQL 方言):
CREATE TABLE translation (
id SERIAL PRIMARY KEY,
language_code CHAR(2) NOT NULL,
key VARCHAR(20) NOT NULL,
value TEXT NOT NULL,
CONSTRAINT translation_unique UNIQUE (language_code, key)
)
数据如下所示:
INSERT INTO translation
(language_code, key, value)
VALUES
('en', 'foo', 'foo in English'),
('nl', 'foo', 'foo in Nederlands (Dutch)'),
('en', 'bar', 'bar in English')
我想基本上做下面的伪 SQL 查询:
SELECT key, value
FROM translation
WHERE (language_code = 'nl' OR IF value IS NULL THEN language_code = 'en')
(其实'nl'
是要参数化的值)
以便它返回以下内容:
+-----+--------------+ | 关键 | 价值 | +-----+--------------+ | 富 | foo 在Nederlands (荷兰语) | 世界银行 | 酒吧 | 酒吧英文| +-----+--------------+
如何在单个 SQL 查询中实现这一点?
有问题的数据库是 PostgreSQL,但与 RDMBS 无关的方式会很好。