mysql的字符串格式化+累加

数据 表t_depart
---------------------------------------------------------------------------
code(vechar 20)        name              parent(vechar 20)
---------------------------------------------------------------------------
01                                         总部            
0101                                    营销一部       01
0102                                     营销二部       01  
0103                                     营销三部       01  
0104                                    营销四部       01  

该表是部门表,无限分类
我现在想实现用程序往表里边添加数据时能自动算出新的部门号,即现在添加总部的子部门01时,下边就应该是0105了

 

 

SELECT right( '10000' + cast( max( code ) AS unsigned ) +1, 4 ) FROM t_depart WHERE parent = '01';

 

从字符串str 开始,返回最右len 字符。加10000是为了能从右取4个数,因此只要是加10000的正数倍都是可以的。

cast()函数主要是为了转化数据类型 CAST(expr AS type)


这个类型 可以是以下值其中的 一个:  

BINARY[(N)]
CHAR[(N)]
DATE
DATETIME
DECIMAL
SIGNED [INTEGER]
TIME
UNSIGNED [INTEGER]

 

其他的就不解释了。

 

转自:http://hi.baidu.com/php_r/blog/item/50a1784b1ca7a7f683025cfa.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值