• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

sql中order by(true or false) 类似 group by 的方式

mysql 搞代码 4年前 (2022-01-09) 28次浏览 已收录 0个评论

适用场景: 如表tab_a 有三个字段, 如果field1非空则按升序排列, 如果field1是空再排field2, 如果 field2非空升序排列, 如果field2是空再排field3, 如果field3非空则升序排列, 如果field3是空。。。。。。。。 或者 你想查询field1x的按照升(降)序排

适用场景:
如表tab_a 有三个字段,
如果field1非空则按升序排列,
如果field1是空再排field2,
如果 field2非空升序排列,
如果field2是空再排field3,
如果field3非空则升序排列,
如果field3是空。。。。。。。。

或者
你想查询field1>x 的按照升(降)序排列,<x 的按照降(升)序排列类似金字塔也可以…… <style> .CodeEntity .code_pieces ul.piece_anchor{width:25px;position:absolute;top:25px;left:-30px;z-index:1000;} .CodeEntity .code_pieces ul.piece_anchor li{width:25px;background: #efe;margin-bottom:2px;} .CodeEntity .code_pieces ul.piece_anchor li{border-left:3px #40AA63 solid;border-right:3px #efe solid;} .CodeEntity .code_pieces ul.piece_anchor li:hover{border-right:3px #40AA63 solid;border-left:3px #efe solid;} .CodeEntity .code_pieces ul.piece_anchor li a{color: #333;padding: 3px 10px;} .CodeEntity .code_pieces .jump_to_code{visibility:hidden;position:relative;} .CodeEntity .code_pieces .code_piece:hover .jump_to_code{visibility:visible;} .CodeEntity .code_pieces .code_piece:hover .jump_to_code a{text-decoration:none;} .CodeEntity .code_pieces h2 i{float:right;font-style:normal;font-weight:normal;} .CodeEntity .code_pieces h2 i a{font-size:9pt;background: #FFFFFF;color:#00A;padding: 2px 5px;text-decoration:none;} </style> <!—ecms

    –> <!—ecms

  • $velocityCount
  • –> <!—ecms

–>

例子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<p>本文来源gao!%daima.com搞$代*!码9网(</p>!='');                  而后面的field1 asc相当于排序field1!=''数据,依次排序field2,field3..........

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:sql中order by(true or false) 类似 group by 的方式
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址