业务需求:

现在业务人员提出了一个需求:

在项目中的工作流,都要有一个流程编号,此编号有一定的规则:

前四五位是流程的字母缩写,中间是8位的日期,后面五位是流水码,要求流水码每天从00001开始。即:QJLC2018060800001

没有想到更好的方式,暂时考虑到了使用oracle的定时器来每天定时的将流水码重置为1。

Oracle数据库表和定时器的创建:

创建任务编码表:

/*==============================================================*/

/* Table: t_flow_taskcode_conf                                  */

/*==============================================================*/

create table t_flow_taskcode_conf  (

flowflag              varchar2(8),

flowab                varchar2(10),

flowcode             NUMBER(5)

);

comment on table t_flow_taskcode_conf is '流程生成任务编号表';

comment on column t_flow_taskcode_conf.flowflag is '流程标识';

comment on column t_flow_taskcode_conf.flowab is '流程四位缩写';

comment on column t_flow_taskcode_conf.flowcode is '流水码';

insert into t_flow_taskcode_conf (FLOWFLAG, FLOWAB, FLOWCODE) values ('QJLC', 'QJLC', 1);

insert into t_flow_taskcode_conf (FLOWFLAG, FLOWAB, FLOWCODE) values ('BGYP', 'BGYP', 1);

insert into t_flow_taskcode_conf (FLOWFLAG, FLOWAB, FLOWCODE) values ('DJBX', 'DJBX', 1);

commit;

创建oracle内部的定时器:

create or replace procedure taskcode_procedure is

begin

update t_flow_taskcode_conf fc set fc.flowcode = 1;

commit;

end;

--定义taskcode每天自动初始化的job任务

declare taskcodejob number;

begin

dbms_job.submit(

taskcodejob,  --定时器ID,系统自动获得

'taskcode_procedure;', --what 执行的存储过程名

sysdate,  --定时器开始执行的时间,这样写表示立即执行 --next_date,可以不填

'TRUNC(sysdate)+1'--'Interval时间字符串' --关键设置,此处表示每天的0点执行

);

commit;

end;

#########下面是一些oracle中的job表和内置定时器函数的介绍:

--  select * from user_jobs;  --查看调度任务

--  select * from dba_jobs_running;--查看正在执行的调度任务

--  select * from dba_jobs;--查看执行完的调度任务

----更新一个job的sql代码

declare

taskcodejob number;

begin

dbms_job.run(3);        --运行jobid为3的定时器

--dbms_job.remove(10);   --9是从user_jobs这个表中查询到然后手动赋值到这里的

--dbms_job.broken(8);    --停止一个job

--dbms_job.interval(84,'TRUNC(sysdate)+15/1440');--更改定时器的运行频率

commit;

end;

项目中的使用

Java代码:

/**
 *
传入流程的标志,返回流程的任务编码
 * @param
taskCodeEnum
 
* @return
 
*/
public String getAndSetTaskCode(FlowTaskCodeEnum taskCodeEnum){
   String flowflag = taskCodeEnum.toString();  //flowflag是”BGYP”,”QJLC”等字符串
   //先获取流程的编码
  
String taskcode = publicCollectDao.getTaskCodeByFlow(flowflag);
   Map<String,Object> map = new HashMap<>();
   map.put("flowflag",flowflag);
   //设置流程的编码加1
  
publicCollectDao.updateFlowCode(map);
   return taskcode;
}

Mybatis的xml文件:

<select id="getTaskCodeByFlow" parameterType="string" resultType="string">

  select fc.flowab||to_char(sysdate,'yyyyMMdd')||lpad(fc.flowcode,5,'0') taskcode

  from t_flow_taskcode_conf fc

  where fc.flowflag = #{flowflag}

</select>

<update id="updateFlowCode" parameterType="map">

  update t_flow_taskcode_conf set flowcode = flowcode+1 where flowflag=#{flowflag}

</update>

上面的java代码,要保证getAndSetTaskCode()方法在使用时开启了事务。

参考:

https://www.cnblogs.com/mingforyou/archive/2012/06/06/2538063.html

https://blog.csdn.net/anrry258/article/details/26555693

注意区分是普通的sql窗口还是commond窗口。

oracle定时器在项目中的应用的更多相关文章

  1. maven新建Spring MVC + MyBatis + Oracle的Web项目中pom.xml文件

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  2. spring项目中如何添加定时器以及在定时器中自动生成sprng注入对象

    最近做了一个java的项目,部门领导给了一套代码让我尽快掌握,说心里话本人真心不喜欢java的这种项目方式,各种配置各种xml文件简直头都大了,下面就将我遇到的其中一个我认为是坑的地方整理出来,希望能 ...

  3. 项目中oracle存储过程记录——经常使用语法备忘

    项目中oracle存储过程记录--经常使用语法备忘 项目中须要写一个oracle存储过程,需求是收集一个复杂查询的内容(涉及到多张表),然后把符合条件的记录插入到目标表中.当中原表之中的一个的日期字段 ...

  4. JavaWeb项目中获取对Oracle操作时抛出的异常错误码

    最近在项目中碰到了这么一个需求,一个JavaWeb项目,数据库用的是Oracle.业务上有一个对一张表的操作功能,当时设置了两个字段联合的唯一约束.由于前断没有对重复字段的校验,需要在插入时如果碰到唯 ...

  5. java web 项目中 简单定时器实现 Timer

    java web 项目中 简单定时器实现 Timer 标签: Java定时器 2016-01-14 17:28 7070人阅读 评论(0) 收藏 举报  分类: JAVA(24)  版权声明:本文为博 ...

  6. vue 项目中,定时器(setInterval)的写法

    vue 项目中,定时器(setInterval)的写法: fetchJobList是一个方法,里面有dispatch一个action进行请求接口的代码. data () { return { inte ...

  7. oracle性能优化(项目中的一个sql优化的简单记录)

    在项目中,写的sql主要以查询为主,但是数据量一大,就会突出sql性能优化的重要性.其实在数据量2000W以内,可以考虑索引,但超过2000W了,就要考虑分库分表这些了.本文主要记录在实际项目中,一个 ...

  8. Oracle 项目中 SQL 脚本更新方式

    DECLARE hasVersion ); dbVersion ); BEGIN ) INTO hasVersion FROM ELB_SETTINGS E WHERE E.KEY='dbVersio ...

  9. 在数据库访问项目中使用微软企业库Enterprise Library,实现多种数据库的支持

    在我们开发很多项目中,数据访问都是必不可少的,有的需要访问Oracle.SQLServer.Mysql这些常规的数据库,也有可能访问SQLite.Access,或者一些我们可能不常用的PostgreS ...

随机推荐

  1. java中的>>>和>>>=

    “>>>”运算符所作的是无符号的位移处理,它不会将所处理的值的最高位视为正负符号,所以作位移处理时,会直接在空出的高位填入0.当我们要作位移的原始值并非代表数值时(例如:表示颜色图素 ...

  2. baidu地图api , 地理位置转 经纬度接口

    更多可以查看    http://lbsyun.baidu.com/index.php?title=webapi/guide/webservice-geocoding 地理编码示例: 以下是关于地理编 ...

  3. Google Protocol Buffer 的使用(未完待续)

    简介 Google Protocol Buffer( 简称 Protobuf) 是 Google 公司内部的混合语言数据标准,目前已经正在使用的有超过 48,162 种报文格式定义和超过 12,183 ...

  4. (Stanford CS224d) Deep Learning and NLP课程笔记(一):Deep NLP

    Stanford大学在2015年开设了一门Deep Learning for Natural Language Processing的课程,广受好评.并在2016年春季再次开课.我将开始这门课程的学习 ...

  5. Spring事务管理入门与进阶

    事务管理 一个数据库事务是一个单一的工作单元操作序列.这些操作应该要么完整地执行,要么完全不执行.事务管理是一个重要组成部分,事务管理可以确保数据完整性和一致性.事务具有以下四个关键特性分别是 ACI ...

  6. Android实时获得经纬度,发送给c++服务端

    Android 客户端: package com.example.admin.gpsget; import android.Manifest; import android.content.Conte ...

  7. 表空间(TableSpace)

    我们知道Oracle数据库真正存放数据的是数据文件(Data File),oracle表空间(tablespace)实际上是一个逻辑的概念,在物理上是并不存在的,那么把一组data files捻在一起 ...

  8. MP4个人制作

  9. 记录windows下编译chromium,备忘

    编译windows下chromium,时间:20170619, 官方地址:https://chromium.googlesource.com/chromium/src/+/master/docs/wi ...

  10. Azure 负载内部均衡器概述

    Azure 内部负载均衡器 (ILB) 仅将流量定向到云服务内的资源,或使用 VPN 来访问 Azure 基础结构. 在这一点上,ILB 与面向 Internet 的负载均衡器不同. Azure 基础 ...