12

我必须从数据库中获取 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 无关的方式会很好。

4

1 回答 1

21

尝试这样的事情:

SELECT
    e.key,COALESCE(o.value,e.value)
    FROM Translation                e
        LEFT OUTER JOIN Translation o ON e.key=o.key and o.language_code='nl'
    WHERE e.language_code='en'
于 2010-07-13T15:30:55.073 回答