您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

mysql 创办自增长订单号

2025/3/22 23:05:49发布27次查看
mysql 创建自增长订单号 因为最近做项目需要,需要使用到,自定义的不重复的自增长的订单号,在网上找了资料然后又加入了自己的修改,做成的mysql生成订单号的存储过程。 drop procedure pp; create procedure proc_get_no (tname varchar(50),cname varchar(
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')
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product