繁体   English   中英

SQL案例| 如果<value>然后<SELECT>

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM