MYSQL补0方式,两种情况,在字段前补0:LPAD(str,len,padstr) ,在字段后补0:RPAD(str,len,padstr)

测试表数据:

SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。
select deptname,sort from t_sm_dept ORDER BY sort;

mysql查询是对字段进行补0操作,可用于树状结构整体排序 随笔 第1张

 查询排序字段sort的最大长度:

select MAX(LENGTH(sort)) from t_sm_dept;

mysql查询是对字段进行补0操作,可用于树状结构整体排序 随笔 第2张

 

1. 在字段前补0:LPAD(str,len,padstr) 

  LPAD(str,len,padstr) 返回字符串 str, 其左边由字符串padstr 填补到len 字符长度。假如str 的长度大于len, 则返回值被缩短至 len 字符。

测试查询:

select sort,LPAD(sort,7,0) from t_sm_dept;

mysql查询是对字段进行补0操作,可用于树状结构整体排序 随笔 第3张

 实际运用:

 查询语句:

select d.deptname,
d.sort,
LPAD(d.sort,(select MAX(LENGTH(sort)) from t_sm_dept),0) as sorttemp
from t_sm_dept d ORDER BY sorttemp;

查询结果:

mysql查询是对字段进行补0操作,可用于树状结构整体排序 随笔 第4张

 

2. 在字段后补0:RPAD(str,len,padstr) 

  RPAD(str,len,padstr) 返回字符串 str, 其右边由字符串padstr 填补到len 字符长度。假如str 的长度大于len, 则返回值被缩短至 len 字符。

测试查询:

select sort,RPAD(sort,7,0) from t_sm_dept;

mysql查询是对字段进行补0操作,可用于树状结构整体排序 随笔 第5张

 实际运用:

查询语句(查询及排序):

select d.deptname,
d.sort,
RPAD(d.SORT,(select MAX(LENGTH(sort)) from t_sm_dept),0) as sorttemp
from t_sm_dept d ORDER BY sorttemp;

查询结果:

mysql查询是对字段进行补0操作,可用于树状结构整体排序 随笔 第6张

如查询结果显示,排序后的结果可以按照层级关系进行整体排序。

 

扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄