小编use*_*164的帖子

有条件的MYSQL where子句

我有一个查询,如果一个名为OrderBy的标志是1,那么它是一个日历事件,我需要检查两个日期时间字段之间的范围.而所有其他类型我们只是检查你正在查看的那一天.我研究if语句并看到很多帖子,其中建议使用一个案例,所以我试着将它实现到我的查询中.我的查询需要在哪里的条件.我知道我有语法问题,这就是为什么我在这里希望有人可以指出正确的方法来做到这一点.

感谢您的时间

我的查询目前

SELECT          activities.*, 
                activitytypes.orderby 
FROM            activities 
LEFT OUTER JOIN activitytypes 
ON              activities.typeid = activitytypes.typeid 
WHERE           activities.userid = 86 
AND             activities.typeid NOT IN ( 5, 
                                          10, 
                                          11, 
                                          12, 
                                          19 ) 
AND 
                CASE 
                                WHEN activities.orderby = 1 THEN activities.starttime >= '2013-08-26 04:00:00' 
                                AND             activities.endtime <= '2013-08-27 04:00:00' 
                                ELSE activities.activitydate = '2013-08-26' 
                                order BY        activitytypes.orderby, 
                                                activities.starttime
Run Code Online (Sandbox Code Playgroud)

mysql conditional case where

5
推荐指数
1
解决办法
2万
查看次数

标签 统计

case ×1

conditional ×1

mysql ×1

where ×1