繁体   English   中英

基于布尔值的SELECT列

[英]SELECT column/s based on boolean value

我有一个左连接选择语句,我想根据具有'0'或'1'的变量的值选择特定的列。 我以为可以用CASE来实现,但是似乎没有运气。

如果$variable包含'0',我希望我的select语句仅检索users.usertable2.total1table2.total2 ,但是如果$variable包含'1',我仅选择users.usertable2.total

$value = '1';
$conn->query(
  "select users.user, table2.total, table2.total1, table2.total2 
  FROM users 
  LEFT JOIN table2 on users.user = table2.total AND $table2.date = CURDATE() 
  WHERE users.user = 'marketing' OR users.user = 'sales'
");

有人有什么想法吗? 谢谢。

您不需要使用sql进行此操作,实际上,如果查询仅因select子句而不同,则可以使用条件变量和变量:

$value = '1'; 

if($variable == '1') {
  $select = "select users.user, table2.total1, table2.total2 ";
}
else {
  $select = "select users.user, table2.total ";
}

$conn->query(
  $select . "
  FROM users 
  LEFT JOIN table2 on users.user = table2.total AND $table2.date = CURDATE() 
  WHERE users.user = 'marketing' OR users.user = 'sales'
");

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

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