MySql 生成自定义格式的编码_并更新保存到表指定的表字段

 

生成出来的编码格式例子:YHCF0000000001、YHCF0000000002、.... 、YHCF0000000010、YHCF0000000011、

mysql sql 

-- 获取最大的编码数据,生成新的自定义格式的编码,并更新保存到表指定的表字段
update m_medicament_info m1
-- 生成的编码已表数据的形式赋值给 m1.sys_goods_code (因为 update 关键字不能有子查询)
INNER JOIN (
    -- 用CONCAT拼接前缀:“YHCF”;
        -- 用 LPAD 拼接编码,每次加 1,数值长度为 10, 左边补充 “0”;
        -- 用 REPLACE 去掉查询出的值的“YHCF”
        -- 用 SELECT 排序查询一条最大编码的数据编码(用于计算下一个编码)
        SELECT CONCAT('YHCF', LPAD(1 + REPLACE((  SELECT mi.sys_goods_code FROM m_medicament_info mi ORDER BY mi.sys_goods_code DESC LIMIT 1 ), 'YHCF', ''), 10, '0')) AS `sysGoodsCode`
) sgc
-- 生成的编码已表数据的形式赋值给 m1.sys_goods_code
set m1.sys_goods_code = sgc.sysGoodsCode
-- 被修改的数据id
where m1.id = 402841;

 

mapper 代码

<update id="produceSysGoodsCode">
    UPDATE m_medicament_info m
    INNER JOIN (
        SELECT CONCAT('YHCF', LPAD(1 + REPLACE(
            ( SELECT mi.sys_goods_code FROM m_medicament_info mi ORDER BY mi.sys_goods_code DESC LIMIT 1 )
        , 'YHCF', ''), 10, '0')) AS `sysGoodsCode`
    ) sgc
    SET m.sys_goods_code = sgc.sysGoodsCode
    WHERE m.id = #{id};
</update>

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wpg_boke

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值