zoukankan      html  css  js  c++  java
  • 生成点餐号的存储过程 mysql

    BEGIN
    DECLARE currentDate varCHAR (15) ;-- 当前日期,有可能包含时分秒
    DECLARE maxNo INT DEFAULT 0 ; -- 离现在最近的满足条件的订单编号的流水号最后5位,如:SH2013011000002的maxNo=2
    -- DECLARE l_orderNo varCHAR (25) ;-- 新生成的订单编号
    -- DECLARE oldDate DATE ;-- 离现在最近的满足条件的订单编号的日期
    DECLARE oldOrderNo VARCHAR (25) DEFAULT '' ;-- 离现在最近的满足条件的订单编号

    if num = 8 then -- 根据年月日生成订单编号
    SELECT DATE_FORMAT(NOW(), '%Y%m%d') INTO currentDate ;-- 订单编号形式:前缀+年月日+流水号,如:SH2013011000002
    elseif num = 14 then -- 根据年月日时分秒生成订单编号
    SELECT DATE_FORMAT(NOW(), '%Y%m%d%H%i%s') INTO currentDate ; -- 订单编号形式:前缀+年月日时分秒+流水号,如:SH2013011010050700001,个人不推荐使用这种方法生成流水号
    else -- 根据年月日时分生成订单编号
    SELECT DATE_FORMAT(NOW(), '%Y%m%d%H%i') INTO currentDate ;-- 订单形式:前缀+年月日时分+流水号,如:SH20130110100900005
    end if ;

    SELECT IFNULL(orderNo, '') INTO oldOrderNo
    FROM catering_orderno
    WHERE SUBSTRING(orderNo, 3, num) = currentDate
    AND SUBSTRING(orderNo, 1, 2) = orderNamePre
    and length(orderNo) = 7 + num AND shopid=shopId
    ORDER BY id DESC LIMIT 1 ; -- 有多条时只显示离现在最近的一条

    IF oldOrderNo != '' THEN
    SET maxNo = CONVERT(SUBSTRING(oldOrderNo, -5), DECIMAL) ;-- SUBSTRING(oldOrderNo, -5):订单编号如果不为‘‘截取订单的最后5位
    END IF ;
    SELECT
    CONCAT(orderNamePre, currentDate, LPAD((maxNo + 1), 5, '0')) INTO newOrderNo ; -- LPAD((maxNo + 1), 5, '0'):如果不足5位,将用0填充左边

    INSERT INTO catering_orderno (orderNo, orderName,shopId) VALUES (newOrderNo, 'testNo',shopId) ; -- 向订单表中插入数据
    -- set newOrderNo = l_orderNo;
    SELECT
    newOrderNo ;
    END

  • 相关阅读:
    Hbase数据备份&&容灾方案
    maven 高级玩法
    Python操作MySQL -即pymysql/SQLAlchemy用法
    python
    Redis的AOF功能
    Redis的快照功能
    查看哪些进程占用了SWAP分区?
    Java进程CPU使用率高排查
    利用iptables实现基于端口的网络流量统计
    从free命令看Linux内存管理
  • 原文地址:https://www.cnblogs.com/wuguangwei/p/14211343.html
Copyright © 2011-2022 走看看