mysql case when

本文介绍了一个具体的SQL查询案例,展示了如何从多个表中选择特定的数据,并通过复杂的条件筛选和排序来优化查询效率。重点关注了AdQualityTaskQueue和AdQualityTask表的联接操作,以及如何根据不同状态和优先级进行数据排序。
SELECT
	`AdQualityTaskQueue`.`id`,
	`AdQualityTaskQueue`.`ad_quality_task_id`,
	`AdQualityTaskQueue`.`ad_quality_workgroup_id`,
	`AdQualityTaskQueue`.`tag_id`,
	`AdQualityTaskQueue`.`created`,
	`AdQualityTaskQueue`.`checked`,
	`AdQualityTaskQueue`.`user_id`,
	`AdQualityTaskQueue`.`completion_time`,
	`AdQualityTaskQueue`.`status`,
	`AdQualityTaskQueue`.`refresh_times`,
	`AdQualityTaskQueue`.`lock_user`,
	`AdQualityTaskQueue`.`lock_expire`,
	`AdQualityTask`.`id`,
	`AdQualityTask`.`name`,
	`AdQualityTask`.`interval`,
	`AdQualityTask`.`duration`,
	`AdQualityTask`.`priority`,
	`AdQualityTask`.`ad_quality_workgroup_id`,
	`AdQualityTask`.`created`,
	`AdQualityTask`.`modified`
FROM
	`ad_quality_task_queues` AS `AdQualityTaskQueue`
LEFT JOIN `ad_quality_tasks` AS `AdQualityTask` ON(
	`AdQualityTaskQueue`.`ad_quality_task_id` = `AdQualityTask`.`id`
)
WHERE
	`AdQualityTaskQueue`.`ad_quality_workgroup_id` = 1
AND(
	(
		`AdQualityTaskQueue`.`lock_user` IS NULL
	)
	OR(
		`AdQualityTaskQueue`.`lock_user` = 162
	)
	OR(
		UNIX_TIMESTAMP(NOW())- UNIX_TIMESTAMP(
			`AdQualityTaskQueue`.`lock_expire`
		)>= 600
	)
)
AND `AdQualityTaskQueue`.`status` IN('DUE', 'OVERDUE')
AND `AdQualityTask`.`priority` IN('MEDIUM', 'HIGH')
ORDER BY
	CASE
WHEN AdQualityTaskQueue.`status` = 'OVERDUE'
AND `AdQualityTask`.`priority` = 'High' THEN
	1
WHEN AdQualityTaskQueue.`status` = 'OVERDUE'
AND `AdQualityTask`.`priority` = 'Medium' THEN
	2
WHEN AdQualityTaskQueue.`status` = 'DUE'
AND `AdQualityTask`.`priority` = 'High' THEN
	3
WHEN AdQualityTaskQueue.`status` = 'DUE'
AND `AdQualityTask`.`priority` = 'Medium' THEN
	4
END ASC,
 `AdQualityTaskQueue`.`checked` ASC
LIMIT 1


case field when xx then xx else xx end;

case when field == xx then xx else xx end;

两种用法区别在于NULL不能够用在第一种情况,因为不能用null通过比较符号< , >, ==, <> 比较。

只能用第二种用法:

case when field is null then xx else xx end;

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值