• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

mysql 创办自增长订单号_mysql

mysql 搞代码 7年前 (2018-06-07) 159次浏览 已收录 0个评论

mysql 创建自增长订单号
因为最近做项目需要,需要使用到,自定义的不重复的自增长的订单号,在网上找了资料然后又加入了自己的修改,做成的mysql生成订单号的存储过程。
drop PROCEDURE pp;
create procedure PROC_GET_NO (tname varchar(50),cname VARCHAR(50),prefix VARCHAR(20))
   begin
     #最终生成的订单号
    declare order_sn VARCHAR(20);

  #当前系统中的订单号
    declare prev VARCHAR(15);
  
  #旧的日期
    declare prevdatetime VARCHAR(15);

  #截取到的编号
    declare sn BIGINT(15);
  
  #当前的系统时间
    declare nowdate VARCHAR(15);

    # 获得当天的最后一条记录编号 判断数据库中的创建日期是否大于当前日期 也就等于是是否是当天的单据

   set @pre = prefix;
   set @na=tname;
     set @cna = cname;
     set @sql_text:=’select MAX(‘;
   set @sql_text := CONCAT(@sql_text,@cna,’) into @recordcount from ‘);
   set @whe :=’ WHERE create_date > CURRENT_DATE()’;
     set @sql_text:=concat(@sql_text,@na,@whe);
     prepare stmt from @sql_text;
     execute stmt;
    set prev = @recordcount;
  #截取日期
    select SUBSTR(prev FROM 2 FOR 9) into prevdatetime;

  #截取编号
    select RIGHT(prev,5) into sn;
  #获得当前的时间 使用now()函数 获得的格式是2014-05-28 11:20:18 然后在获取自己想要的数据
    select DATE_FORMAT(NOW(),’%Y%m%d’) into nowdate;
    #判断最后一条记录是否为空
    if isnull(prev) then
        select concat(@pre,nowdate,’00001′) into order_sn;
            #return order_sn;
        elseif nowdate = prevdatetime then
            select concat(@pre,nowdate,’00001′) into order_sn;
            #return order_sn;
        else
        select concat(@pre,prevdatetime,LPAD((sn+1),4,’0′))into order_sn;
        #return order_sn;
        end if;
select order_sn;

     end;
CALL pp(‘quotation’,’quotation_no’,’O’)

欢迎大家阅读《mysql 创办自增长订单号_mysql》,跪求各位点评,by 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:mysql 创办自增长订单号_mysql

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址