mysql 根据状态值排序_MySQL如何对数据库状态值指定排序

在MySQL中,当需要按照特定顺序对状态值进行排序,而非默认升序或降序时,可以使用FIELD()函数。例如,对于一个业务表,状态值排序规则为:待审批 > 驳回 > 委托 > 通过 > 不通过。通过如下SQL查询实现该排序:`SELECT * FROM test_process ORDER BY FIELD(status, 0, 3, 4, 1) ASC`。这将使无匹配状态值排在最后(如状态值2)。" 111447485,10324568,PyQt学习:QFontComboBox与字体属性解析,"['Python GUI', 'Qt', 'GUI开发', 'PyQt']

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

问题描述:有一个业务表,其状态值有以下几种

0:"待审批",1:"通过",2:"不通过",3:"驳回",4:"委托",

我的排序规则既不是 order by status desc 也不是 asc

而是按照  待审批 > 驳回 > 委托 > 通过 >不通过 的顺序排序

CREATE TABLE IF NOT EXISTS `test_process` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`status` int(11) DEFAULT 0,

`statusDesc` varchar(20) DEFAULT '',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1;

insert into test_process (status,statusDesc) value (0,'wait_approval');

insert into test_process (status,statusDesc) value (1,'pass');

insert into test_process (status,statusDesc) value (2,'not_pass');

insert into test_process (status,statusDesc) value (3,'callback');

insert into test_process (status,statusDesc) value (4,'entrust');

数据如下:

c58610a6fc2efe0a3ce21c8be738abc7.png

此时应当使用field函数:

select * from test_process order by field(status,0,3,4,1) asc;

输出结果:

78fe68ee678d59cd852adcba1027d5bc.png

按照后面的值正序排列,无匹配的将会放在最前面(比如2)

06b722452c0c4582df1b581bdbf0887c.png

倒序时候,依据值最前面的值的匹配行的放在最后面,无匹配状态值将作为状态值列表的最前面的状态值(2)对应匹配行放在最后面

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值