单号生成1

CREATE OR REPLACE FUNCTION FC_GET_DJBH(v_djlx VARCHAR2,
v_table_name VARCHAR2,
v_ywrq VARCHAR2)
/*
* v_djlx: 单据类型
* v_table_name:编码所在表名
* v_number_col:编码所在列名
*/
RETURN VARCHAR2 IS
v_no VARCHAR2(50):=‘‘; --原编码
v_num NUMBER; --原编码后三位编号
v_ywrqQF VARCHAR2(2);--判断v_ywrq是否含有‘-‘
v_sql VARCHAR2(4000);
v_ywrq1 VARCHAR2(10);--保存不含‘-‘的v_ywrq
begin

v_sql :=‘select nvl(max(reverse(substr(reverse(DJBH),1,2)))+1,1) from ‘|| v_table_name||
‘ where instr(DJBH,‘‘‘||v_djlx||‘‘‘)>0 and to_char(YWRQ,‘‘yyyy-mm-dd‘‘) =‘‘‘||v_ywrq||‘‘‘‘;

--and instr(DJBH,V_DJLX)>0;
EXECUTE IMMEDIATE v_sql INTO v_num;

--v_ywrq1 := v_ywrq;

select translate(v_ywrq, ‘-‘, ‘‘) into v_ywrq1 from dual;

--v_ywrq如果包含字符串‘-‘,要去换掉
select instr(v_ywrq,‘-‘) into v_ywrqQF from dual;
if ascii(v_ywrqQF) > ascii(‘0‘) THEN
select TO_CHAR(TO_DATE(v_ywrq, ‘YYYY-MM-DD‘),‘YYYYMMDD‘) into v_ywrq1 from dual;
-- select translate(v_ywrq, ‘-‘, ‘‘) into v_ywrq1 from dual;
end if;
--select translate( ‘00000921000001 ‘, ‘921‘, ‘924‘) from dual;

v_no := v_djlx||v_ywrq1||‘-‘||lpad(v_num, 2, ‘0‘);
RETURN v_no;
EXCEPTION
WHEN OTHERS THEN
dbms_output.put_line(SQLERRM);
END FC_GET_DJBH;

时间: 2024-12-18 19:19:36

单号生成1的相关文章

系统中生成编号/单号问题的实现方案讨论

应用场景 场景:对于大多数电商系统或财务系统来说,系统中的单号一般都不是从1开始的自增数字,而是一串有一定意义的字符串序列. 而往往这样的单号是要全局唯一的,不可重复. 那么,每次新增订单记录时,这个单号就要按照指定的规则来生成. 常见的订单号规则是字母前缀+日期+时间+定长的数字,如DD201610201559060001(format:XXYYYYMMDDHHmmssNNNN),PZ16102015000012(format:XXYYMMDDHHNNNNNN) 常见方案... 实现这样的场景

分布式系统中的必备良药 —— 全局唯一单据号生成

阅读目录 单据号是指什么 和唯一ID的不同是什么 为什么需要全局唯一单据号生成程序 实现的方式有哪些 笔者推荐的方式 结语 一.单据号是指什么 我们作为一个软件系统,肯定到处充满着各种单据,也必然需要有各种单据号与之对应.比如:电商行业的订单号.支付流水号.退款单号等等.SCM的采购单号.进货单号.出货单号.盘点单号等.在一个企业内部或者一个2C的平台,无法避免的需要通过某个单据号来进行沟通.所以一个好的单据号必然是便于沟通的,简单来说优先级就是 好记 > 好输入 > 好看,当然也是越短越好.

zf-关于邵阳市打印模块个别单号打印之后不会跳转到收费模块的BUG的解决方法

原因是 办结的时候 有个收费管理,里面会生成收费项目的单号,但是有1个单号是有问题的,没有关联到数据库里面的其他的表,所以打印之后不能跳转.如果跳转到收费模块 那么数据库里面的一个flag字段会变成9. 解决方法是 把这条数据删掉,然后重新创建一个一模一样的数据(注意:oid一定要一样才行)然后就解决了,之所以能解决目测是因为这个其他的表管理这个收费项目的表的时候,这个收费项目是本身就存在的,然而,如果要关联成功,需要在关联之后插入才可行.因此把这条数据删除之后重新插入一行一模一样的数据就OK了

免费物流快递单号查询接口快速对接指南

[场景需求描述] 电商平台及ISV商家对物流api接口的需求有很多,今天我们主要分享的就是快递鸟快递单号查询接口的对接指南,快递单号查询接口对接的应用场景有很多,很多场景会遇到,最主要的就是电商网站用户打开"我的订单"时调用此API显示物流信息详情,电商管理后台的物流系统,客服在对账前查询所有运单的签收状态,并追踪问题,电商平台对商家物流管控,要求必须在多久快递必须发出要看到揽件状态,多久必须收到货物看到签收状态,根据这些状态对商家管控从而提高用户的整体满意度.下图是电商平台.买家.商

免费顺丰快递单号查询电子面单api接口对接【快递鸟API】

顺丰速运快递查询接口API和电子面单接口怎么对接?除了通过顺丰自己的接口对接外,用的最多的就是第三方通过快递鸟对接了,通过顺丰单号和手机号后四位查询轨迹信息,如果是通过快递鸟下单获得的顺丰单号,可通过单号直接查询,具体下载快递鸟接口技术文档查看接口说明.ShipperCode为SF,且快递单号非快递鸟渠道返回时,必填,对应收件人/寄件人手机号后四位:ShipperCode为SF,且快递单号为快递鸟渠道返回时,不填. 一.接入前准备(TO商家业务人员) 1.申请快递鸟用户ID和API key1.1

电商网站物流快递单号查询api接口申请案例

[场景需求描述] 电商平台及ISV商家对物流api接口的需求有很多,今天我们主要分享的就是快递鸟快递单号查询接口的对接指南,快递单号查询接口对接的应用场景有很多,很多场景会遇到,最主要的就是电商网站用户打开"我的订单"时调用此API显示物流信息详情,电商管理后台的物流系统,客服在对账前查询所有运单的签收状态,并追踪问题,电商平台对商家物流管控,要求必须在多久快递必须发出要看到揽件状态,多久必须收到货物看到签收状态,根据这些状态对商家管控从而提升用户的整体满意度.[对接使用流程] 1.注

常用快递单号查询api接口对接案例(快递鸟&菜鸟)

目前提供快递查询的接口平台有: 快递鸟 (非淘系用户使用最多) 菜鸟 (淘系用户使用) 不同接口的区别: (1)快递鸟支持400多家物流快递公司,接口稳定免费,提供多种方式接口对接 (2)菜鸟支持100多家物流快递公司接口,主要支持阿里淘系商家用户使用. 快递API的应用场景与用途 最常见的应用场景如下: (1)电商网站:例如B2C.团购.B2B.批发分销站.C2C.本地生活交易等网站. (2)管理系统:订单处理平台.订货平台.发货平台.分销系统.渠道管理系统.客户管理系统.ERP等. 快递AP

常用快递单号物流查询API接口通用对接指南(JAVA快递鸟对接)

快递查询接口通用API是给发货电商用来实现查询快递物流轨迹功能的,接口对接前要先到快递鸟网站申请接口秘钥和APIKEY 快递API的应用场景与用途 最常见的应用场景如下: (1)电商网站:例如B2C.团购.B2B.批发分销站.C2C.本地生活交易等网站. (2)管理系统:订单处理平台.订货平台.发货平台.分销系统.渠道管理系统.客户管理系统.ERP等. 快递API的用途如下: (1)让顾客登录网站后,直接在“我的订单”页面内就能看到订单的物流状态. (2)自动筛选出“已签收”.“疑难件”等状态的

基于mysql的单据号生成(前缀+日期+自增id+后缀)

介绍 本次采用mysql处理,性能不是很好,对于高并发有要求的建议不要采用公司一个小项目,需要生成一个单据号,格式为: 日期 + 每日重新自增号,自己考虑了一下每日自增需要考虑并发和持久问题,两种数据库redis和mysql由于项目较小,所以没有redis因为这个增加一个redis好像有点不值得,所以采用mysql作为持久化处理,一下思路也是借鉴了网上的许多想法 源码 源码查看规则源码位置: blog-study:module-utils:work-no 欢迎大家随时批评指正 思路 首先根据需求