适用场景: 如表tab_a 有三个字段, 如果field1非空则按升序排列, 如果field1是空再排field2, 如果 field2非空升序排列, 如果field2是空再排field3, 如果field3非空则升序排列, 如果field3是空。。。。。。。。 或者 你想查询field1x的按照升(降)序排
适用场景:
如表tab_a 有三个字段,
如果field1非空则按升序排列,
如果field1是空再排field2,
如果 field2非空升序排列,
如果field2是空再排field3,
如果field3非空则升序排列,
如果field3是空。。。。。。。。
或者
你想查询field1>x 的按照升(降)序排列, 例子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..........