[英]SQL case | If <value> then <SELECT>
我想SELECT
基于用户的语言(德语或英语)从表中的值。 我知道我可以稍后在 PHP 中进行选择 if/else 但我想尝试是否可以在我的 SQL 查询中进行选择。 我在 SQL CASE
的文档中没有看到满足我需求的示例或解决方案。 我不确定这是否可能。 正如我所看到的, THEN
只接受“文本”,但没有新的 SQL 查询。
我的 SQL 查询
$statement = $pdo->prepare("SELECT
audit.id as audit_id,
audit.questionaire_id,
audit.assigned_auditor,
audit.co_auditor_1_id,
audit.co_auditor_2_id,
audit.comment_positive,
audit.comment_negative,
audit.comment_general,
audit.general_audit_status,
audit.questionaire_id,
audit.audit_date_start,
audit.audit_date_end,
audit.audit_reason,
audit.audited_process,
audit.area,
departments.name,
departments.location,
suppliers.supplier_name,
suppliers.supplier_country,
suppliers.supplier_city,
users.vorname,
users.nachname,
users.email,
questionaire.scheme,
questionaire.quest_name, //German translation
questionaire.quest_name_en // English translation
FROM audit
LEFT JOIN suppliers
ON audit.supplier_id = suppliers.id
LEFT JOIN users
ON audit.supplier_uid = users.id
LEFT JOIN departments
ON audit.department = departments.id
JOIN questionaire
ON audit.questionaire_id = questionaire.id
WHERE audit.id = $id");
$result = $statement->execute(array(':id' => $_GET['id']));
$audit = $statement->fetch();
在这里,我想实现这种 SQL CASE
情况的部分:
我的尝试:
... things before ...
questionaire.scheme,
CASE users.language = 'de' THEN
(SELECT quest_name FROM questionaire WHERE id = audit.questionaire_id)
ELSE (SELECT quest_name_en FROM questionaire WHERE id = audit.questionaire_id)
FROM audit
... things after ...
不需要像您的查询已经将必要的表连接在一起那样复杂。 所以代替
CASE users.language = 'de' THEN
(SELECT quest_name FROM questionaire WHERE id = audit.questionaire_id)
ELSE (SELECT quest_name_en FROM questionaire WHERE id = audit.questionaire_id)
采用
CASE
WHEN users.language = 'de' THEN quest_name
ELSE quest_name_en
END
这是我知道的用于 Oracle 或 SQL Server 的 SQL。 在这种类型的 CASE 中,您可以检查多种类型,因为条件在 WHEN 子句中。
选择
CASE users.language
WHEN 'de' THEN quest_name
ELSE quest_name_en
END
在这种情况下,类型是由 CASE 预先设置的,因此 WHEN 只能针对相同的类型进行评估。 就像在这种情况下只针对字符串。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.