• 生成流水订单编号


    mysql 生成流水订单号 存储过程 订单编号

    测试订单表(test_orders):

    1. CREATE TABLE 'test_orders'(
    2.  'id' int(11) NOT NULL AUTO_INCREMENT,
    3. 'orderNo' varchar(25) NOT NULL DEFAULT '',     
    4. 'orderName' char(10) NOT NULL DEFAULT '',
    5. PRIMARY KEY ('id'),
    6. ) ENGINE=InnoDB AUTO_INCREMENT=76 DEFAULT CHARSET=utf8 

     

    生成订单编号的存储过程(generate_orderNo):

    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 tb_orderids
    WHERE SUBSTRING(orderNo, 3, num) = currentDate
    AND SUBSTRING(orderNo, 1, 2) = orderNamePre
    and length(orderNo) = 7 + num
    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 tb_orderids (orderNo, orderName) VALUES (newOrderNo, 'testNo') ; -- 向订单表中插入数据
    -- set newOrderNo = l_orderNo;
    SELECT
    newOrderNo ;
    END

    java调用过程

    public String generate_orderNo() {

    CallableStatement cs = null;
    Connection conn = null;
    ResultSet rs = null;
    try {
    DataSource dataSource=TransactionManager.getSource();
    conn = dataSource.getConnection();
    cs = conn.prepareCall("{call generate_orderNo(?,?,?) }");
    // 设置输入参数
    cs.setInt(2, 12);//(2, 12);
    cs.registerOutParameter(3, Types.VARCHAR);
    cs.execute();
    // 设置输出参数
    String OrderID = cs.getString(3);
    return OrderID;
    } catch (Exception e) {
    e.printStackTrace();
    throw new RuntimeException("生成订单号失败");
    }

  • 相关阅读:
    告别单身淘宝小店
    微信机器人 细腻化
    # 导入模块 from wxpy import * # 初始化机器人,扫码登陆 bot = Bot()
    减小文件大小 减少 帧
    无有效图视频
    生成一张白色图片的算法--逻辑
    加logo
    字幕 3系数
    音频分析 字幕同步
    尊重百度的api语音合成规则
  • 原文地址:https://www.cnblogs.com/wangjiagang/p/5767961.html
Copyright © 2020-2023  润新知