IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> xxl-job更换oracle数据源 -> 正文阅读

[大数据]xxl-job更换oracle数据源

参考:继springboot集成xxl-job-01的补充--oracle版本的xxl-job项目(任务调度中心)_过客匆匆@1的博客-CSDN博客

XxlJob(2.2.1)Mysql转Oracle解决方案_秦少-CSDN博客_mysql转oracle方案

?看了网上的解决方案,发现还是有一些地方没有说到,但又不得不改的地方记录一下

我下载的是XXL-JOB v2.3.0

步骤1,下载xxl-jobj? ?jar包,解压导入到idea

步骤2,在oracle库中运行sql语句(XXL-JOB v2.3.0/doc/db)

把改完的sql贴一下

CREATE TABLE xxl_job_info (
  id number(11) NOT NULL primary key,
  job_group number(11) NOT NULL,
  job_desc varchar2(255) NOT NULL,
  add_time timestamp DEFAULT NULL,
  update_time timestamp DEFAULT NULL,
  author varchar2(64) DEFAULT NULL,
  alarm_email varchar2(255) DEFAULT NULL,
  schedule_type varchar2(50) DEFAULT 'NONE' NOT NULL,
  schedule_conf varchar2(128) DEFAULT NULL,
  misfire_strategy varchar2(50) DEFAULT 'DO_NOTHING' NOT NULL,
  executor_route_strategy varchar2(50) DEFAULT NULL,
  executor_handler varchar2(255) DEFAULT NULL,
  executor_param varchar2(512) DEFAULT NULL,
  executor_block_strategy varchar2(50) DEFAULT NULL,
  executor_timeout number(11) DEFAULT '0' NOT NULL,
  executor_fail_retry_count number(11) DEFAULT '0' NOT NULL,
  glue_type varchar2(50) NOT NULL,
  glue_source clob,
  glue_remark varchar2(128) DEFAULT NULL,
  glue_updatetime timestamp DEFAULT NULL,
  child_jobid varchar2(255) DEFAULT NULL,
  trigger_status number(4) DEFAULT '0' NOT NULL,
  trigger_last_time number(13) DEFAULT '0' NOT NULL,
  trigger_next_time number(13) DEFAULT '0' NOT NULL
)

comment on column xxl_job_info.job_group is '执行器主键ID';
comment on column xxl_job_info.author is '作者';
comment on column xxl_job_info.alarm_email is '报警邮件';
comment on column xxl_job_info.schedule_type is '调度类型';
comment on column xxl_job_info.schedule_conf is '调度配置,值含义取决于调度类型';
comment on column xxl_job_info.misfire_strategy is '调度过期策略';
comment on column xxl_job_info.executor_route_strategy is '执行器路由策略';
comment on column xxl_job_info.executor_handler is '执行器任务handler';
comment on column xxl_job_info.executor_param is '执行器任务参数';
comment on column xxl_job_info.executor_block_strategy is '阻塞处理策略';
comment on column xxl_job_info.executor_timeout is '任务执行超时时间,单位秒';
comment on column xxl_job_info.executor_fail_retry_count is '失败重试次数';
comment on column xxl_job_info.glue_type is 'GLUE类型';
comment on column xxl_job_info.glue_source is 'GLUE源代码';
comment on column xxl_job_info.glue_remark is 'GLUE备注';
comment on column xxl_job_info.glue_updatetime is 'GLUE更新时间';
comment on column xxl_job_info.child_jobid is '子任务ID,多个逗号分隔';
comment on column xxl_job_info.trigger_status is '调度状态:0-停止,1-运行';
comment on column xxl_job_info.trigger_last_time is '上次调度时间';
comment on column xxl_job_info.trigger_next_time is '下次调度时间';

CREATE TABLE xxl_job_log (
  id number(20) NOT NULL primary key,
  job_group number(11) NOT NULL,
  job_id number(11) NOT NULL,
  executor_address varchar2(255) DEFAULT NULL,
  executor_handler varchar2(255) DEFAULT NULL,
  executor_param varchar2(512) DEFAULT NULL,
  executor_sharding_param varchar2(20) DEFAULT NULL,
  executor_fail_retry_count number(11) DEFAULT '0' NOT NULL,
  trigger_time timestamp DEFAULT NULL,
  trigger_code number(11) NOT NULL,
  trigger_msg varchar2(1000),
  handle_time timestamp DEFAULT NULL,
  handle_code number(11) NOT NULL,
  handle_msg varchar2(1000),
  alarm_status number(4) DEFAULT '0' NOT NULL
)

comment on column xxl_job_log.job_group is '执行器主键ID';
comment on column xxl_job_log.job_id is '任务,主键ID';
comment on column xxl_job_log.executor_address is '执行器地址,本次执行的地址';
comment on column xxl_job_log.executor_handler is '执行器任务handler';
comment on column xxl_job_log.executor_param is '执行器任务参数';
comment on column xxl_job_log.executor_sharding_param is '执行器任务分片参数,格式如 1/2';
comment on column xxl_job_log.executor_fail_retry_count is '失败重试次数';
comment on column xxl_job_log.trigger_time is '调度-时间';
comment on column xxl_job_log.trigger_code is '调度-结果';
comment on column xxl_job_log.trigger_msg is '调度-日志';
comment on column xxl_job_log.handle_time is '执行-时间';
comment on column xxl_job_log.handle_code is '执行-状态';
comment on column xxl_job_log.handle_msg is '执行-日志';
comment on column xxl_job_log.alarm_status is '告警状态:0-默认、1-无需告警、2-告警成功、3-告警失败';

CREATE TABLE xxl_job_log_report (
  id number(11) NOT NULL primary key,
  trigger_day timestamp DEFAULT NULL,
  running_count number(11) DEFAULT '0' NOT NULL,
  suc_count number(11) DEFAULT '0' NOT NULL,
  fail_count number(11) DEFAULT '0' NOT NULL,
  update_time timestamp DEFAULT NULL
)

comment on column xxl_job_log_report.trigger_day is '调度-时间';
comment on column xxl_job_log_report.running_count is '运行中-日志数量';
comment on column xxl_job_log_report.suc_count is '执行成功-日志数量';
comment on column xxl_job_log_report.fail_count is '执行失败-日志数量';


CREATE TABLE xxl_job_logglue (
  id number(11) NOT NULL primary key,
  job_id number(11) NOT NULL,
  glue_type varchar2(50) DEFAULT NULL,
  glue_source clob,
  glue_remark varchar2(128) NOT NULL,
  add_time timestamp DEFAULT NULL,
  update_time timestamp DEFAULT NULL
)

comment on column xxl_job_logglue.job_id is '任务,主键ID';
comment on column xxl_job_logglue.glue_type is 'GLUE类型';
comment on column xxl_job_logglue.glue_source is 'GLUE源代码';
comment on column xxl_job_logglue.glue_remark is 'GLUE备注';

CREATE TABLE xxl_job_registry (
  id number(11) NOT NULL primary key,
  registry_group varchar2(50) NOT NULL,
  registry_key varchar2(255) NOT NULL,
  registry_value varchar2(255) NOT NULL,
  update_time timestamp DEFAULT NULL
)

CREATE TABLE xxl_job_group (
  id number(11) NOT NULL primary key,
  app_name varchar2(64) NOT NULL,
  title varchar2(12) NOT NULL,
  address_type number(4) DEFAULT '0' NOT NULL,
  address_list varchar2(100),
  update_time timestamp DEFAULT NULL
)

comment on column xxl_job_group.app_name is '执行器AppName';
comment on column xxl_job_group.title is '执行器名称';
comment on column xxl_job_group.address_type is '执行器地址类型:0=自动注册、1=手动录入';
comment on column xxl_job_group.address_list is '执行器地址列表,多地址逗号分隔';

CREATE TABLE xxl_job_user (
  id number(11) NOT NULL primary key,
  username varchar2(50) NOT NULL,
  password varchar2(50) NOT NULL,
  role number(4) NOT NULL,
  permission varchar2(255) DEFAULT NULL
)

comment on column xxl_job_user.username is '账号';
comment on column xxl_job_user.password is '密码';
comment on column xxl_job_user.role is '角色:0-普通用户、1-管理员';
comment on column xxl_job_user.permission is '权限:执行器ID列表,多个逗号分割';

CREATE TABLE xxl_job_lock (
  lock_name varchar2(50) NOT NULL primary key
)

comment on column xxl_job_lock.lock_name is '锁名称';

comment on table xxl_job_lock is '任务调度锁表';
comment on table xxl_job_group is '执行器信息表';
comment on table xxl_job_info is '调度扩展信息表';
comment on table xxl_job_log is '调度日志表';
comment on table xxl_job_log_report is '调度日志报表';
comment on table xxl_job_logglue is '任务GLUE日志';
comment on table xxl_job_registry is '执行器注册表';
comment on table xxl_job_user is '系统用户表';

步骤3,更改xxl-job-admin中数据源的连接方式,同时把hikari的测试连接语句把select 1改为select * from dual

步骤4,更改mysql和oracle的语法?


<![CDATA[ ]]>:如果写的sql中有一些特殊的字符的话,在解析xml文件的时候会被转义,但我们不希望他被转义,所以我们要使用<![CDATA[ ]]>来解决

1、把`和;全部除去

2、注意:把 AS 别名 改为"别名"

理由:XxlJobServiceImpl中有一个charInfo()获取主页关于调度结果的数据展示信息,下图箭头标注的地方,加入别名不加"",sql语句查出的数据的属性名默认大小,而方法里查出来数据的map通过containKey()方法判断有没有数据

?3、mysql是主键自增,oracel用序列

// 创建序列    所有的表都需要创建序列
CREATE SEQUENCE xxl_job_log_report_seq
INCREMENT BY 1 #增长值
START WITH 1  #开始值
NOMAXvalue #没有最大值
NOCYCLE;    #不循环

CREATE SEQUENCE xxl_job_log_seq
INCREMENT BY 1 
START WITH 1 
NOMAXvalue 
NOCYCLE;

CREATE SEQUENCE xxl_job_registry_seq
INCREMENT BY 1 
START WITH 1 
NOMAXvalue 
NOCYCLE;

CREATE SEQUENCE xxl_job_info_seq
INCREMENT BY 1 
START WITH 1 
NOMAXvalue 
NOCYCLE;

CREATE SEQUENCE xxl_job_group_seq
INCREMENT BY 1 
START WITH 1 
NOMAXvalue 
NOCYCLE;


CREATE SEQUENCE xxl_job_logglue_seq
INCREMENT BY 1 
START WITH 1 
NOMAXvalue 
NOCYCLE;

CREATE SEQUENCE xxl_job_user_seq
INCREMENT BY 1 
START WITH 1 
NOMAXvalue 
NOCYCLE;

DROP SEQUENCE XXL_JOB_LOG_seq;  #删除序列

4、DATE_ADD(#{nowTime},INTERVAL -#{timeout} SECOND)改为

(#{nowTime}+numtodsinterval(-#{timeout},'SECOND'))

5、 !改为not

?6、limit 改为rownum

ORACLE 中ROWNUM用法总结!_java之路-CSDN博客_oracle rownum

?7、update和insert语法中最好加上指定的jdbcType=VARCHAR类型

?当出传进来的值为null时,会报错无效的列类型,只需要把#{name}改为#{name,jdbcType=VARCHAR},就可以避免

到这里需要改的都说完了,之后运行项目,通过链接http://127.0.0.1:8080/xxl-job-admin/就可以看到页面?

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-12 17:36:19  更:2022-03-12 17:39:16 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 18:37:34-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码