关于order by后面接条件查询

本文介绍了一种在SQL中实现复杂条件排序的方法,特别是在处理多个字段并根据非空情况及布尔值进行升序或降序排列的场景。通过具体实例演示了如何在不同字段间进行灵活切换,以达到预期的排序效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

             

  适用场景,如表tab_a 有三个字段,

                          如果field1非空则按升序排列,

                               如果field1是空再排field2,

                                       如果 field2非空升序排列,

如果field2是空再排field3,

如果field3非空则升序排列,

如果field3是空。。。。。。。。



例子1    排序boolean类型

CREATE TABLE `tab_b` (
  `field` varchar(255) default NULL,
  `id` int(11) default NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


INSERT INTO `tab_b` VALUES ('1', 'ture');

INSERT INTO `tab_b` VALUES ('2', 'ture');

INSERT INTO `tab_b` VALUES ('3', 'false');

INSERT INTO `tab_b` VALUES ('4', 'false');


SELECT * from TAB_B ORDER BY  field='true' desc



注意:ORDER  by 后接的字段如果是boolean属性,则false比ture ‘大’!!!!!

                  

########################################################


DROP TABLE IF EXISTS `tab_a`;
CREATE TABLE `tab_a` (
  `id` int(11) NOT NULL,
  `field3` int(11) default NULL,
  `field2` int(11) default NULL,
  `field1` int(11) default NULL,
  PRIMARY KEY  (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;


INSERT INTO `tab_a` VALUES ('1', '1', '1', '1');
INSERT INTO `tab_a` VALUES ('2', '2', '2', '2');
INSERT INTO `tab_a` VALUES ('3', '3', '3', null);
INSERT INTO `tab_a` VALUES ('4', '4', null, null);
INSERT INTO `tab_a` VALUES ('5', '5', '5', null);
INSERT INTO `tab_a` VALUES ('6', null, null, null);
INSERT INTO `tab_a` VALUES ('7', null, null, null);
INSERT INTO `tab_a` VALUES ('8', '8', null, null);

SELECT  * FROM TAB_A  ORDER BY 
  field1='' desc , field1 asc, 
  field2='' desc , field2 asc,
  field3='' desc  ,field3 asc 



            此处field1='' 可以看成boolean排序  desc 排序,field1=''为真的排在下面(因为看上面"注意"),否则排在上面(即field1!='');

                  而后面的field1 asc相当于排序field1!=''数据,依次排序field2,field3..........








引用\[1\]和\[2\]提供了两个示例,展示了在SQL查询中使用order by和case when语句的用法。在这些示例中,order by后面的是一个case when语句,用于根据特定条件对结果进行排序。 在\[1\]的示例中,根据学生的课程进行排序,当课程为语文课时排在最前面,数学课次之,物理课再次之,其他课程排在最后。 在\[2\]的示例中,根据产品的名称进行排序,当产品为方太吸油烟机时排在最前面,方太消毒柜次之,以此类推,其他产品排在最后。 因此,当order by后面case when语句时,可以根据特定条件对结果进行排序。 #### 引用[.reference_title] - *1* [sql语句中 order by利用case when实现排序(简单使用)](https://blog.youkuaiyun.com/wuzj1314/article/details/126816405)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [order by 子句 后面跟 case when](https://blog.youkuaiyun.com/qianyuanruqu/article/details/87617517)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [记录 mysqlorder by 结合 case when 实现多条件排序.](https://blog.youkuaiyun.com/weixin_44821980/article/details/129242218)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值