项目需要:
自定义的不重复的自增长的订单号,分享一个mysql生成订单号的存储过程。
sql语句如下:
 
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')