mysql数据库 ,java 代码巧妙结合提升系统性能。
查询频繁的表t_yh_transport_task
- 保证数据量最少,增加查询效率,
- 常用于查询的字段增加索引,
- 每日定时移动数据
<!-- 医院系统预约任务历史删除定时器 -->
<bean name="delHosTaskTimer" class="org.springframework.scheduling.quartz.JobDetailBean">
<property name="jobClass" value="com.yh.utils.timer.DelHosTaskTimer" />
</bean>
<!-- 定时任务触发器 -->
<bean id="delHosTaskTimerTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail" ref="delHosTaskTimer" />
<!-- <property name="cronExpression" value="0 0 1 * * ?" /> --><!--每天1点运行一次 -->
<property name="cronExpression" value="0 */1 * * * ?" /><!--每1分钟运行一次 -->
</bean> - public class DelHosTaskTimer extends QuartzJobBean{具体业务逻辑}
- 或者:mysql中写
一个存储过程,每日定时移动数据。 - 存储过程:
BEGIN
DECLARE
counts INTEGER;-- 记录迁移条数
-- DECLARE
-- '2018-07-01' datetime;-- 定义一个时间变量用来存放时间
DECLARE
result_code INTEGER;-- 定义返回结果并赋初始值
DECLARE
CONTINUE HANDLER FOR SQLEXCEPTION
SET result_code = 1;-- 在执行过程中出现任何异常result_code为1
-- SELECT
-- '2018-07-01' INTO '2018-07-01';-- 获取今日零点三个月之前的时间
SELECT
count(1) INTO counts
FROM
(
SELECT
t.*
FROM
t_yh_transport_task t
WHERE
t.task_type = 1
AND t.`create_time` <= '2018-07-01'
UNION
SELECT
t.*
FROM
t_yh_transport_task t
LEFT JOIN t_yh_ordertask_extend e ON e.transport_task_id = t.transport_task_id
WHERE
t.task_type = 2
AND e.`order_time` <= '2018-07-01'
) a;
-- WHERE
-- a.task_status = '33'
-- OR a.task_status = '99';START TRANSACTION;
-- 进行事物处理
-- 向历史表插入历史数据
INSERT INTO t_yh_transport_task_history SELECT
NULL,
a.transport_task_id,
a.user_id,
a.create_time,
a.task_Ftype,
a.task_Ctype,
a.task_content,
a.task_org,
a.transport_tool,
a.task_Departure,
a.task_Destination,
a.task_status,
a.task_startTime,
a.task_endTime,
a.exc_user_id,
a.task_detail,
a.affiliated_hospital,
a.owned_property,
a.task_type,
a.cancel_reason,
a.parent_task_id,
a.destination_org,
a.task_code,
a.task_from,
a.is_lock,
now(),
a.change_tool_time,
a.end_reason,
a.update_time,
a.plan_no,
a.wandaihao
FROM
(
SELECT
t.*
FROM
t_yh_transport_task t
WHERE
t.task_type = 1
AND t.`create_time` <= '2018-07-01'
UNION
SELECT
t.*
FROM
t_yh_transport_task t
LEFT JOIN t_yh_ordertask_extend e ON e.transport_task_id = t.transport_task_id
WHERE
t.task_type = 2
AND e.`order_time` <= '2018-07-01'
) a;
-- WHERE
-- a.task_status = '33'
-- OR a.task_status = '99';-- 插入后删除三个月前的数据
DELETE
FROM
t_yh_transport_task
WHERE
t_yh_transport_task.transport_task_id IN (
SELECT
a.transport_task_id
FROM
(
SELECT
t.*
FROM
t_yh_transport_task t
WHERE
t.task_type = 1
AND t.`create_time` <= '2018-07-01'
UNION
SELECT
t.*
FROM
t_yh_transport_task t
LEFT JOIN t_yh_ordertask_extend e ON e.transport_task_id = t.transport_task_id
WHERE
t.task_type = 2
AND e.`order_time` <= '2018-07-01'
) a
-- WHERE
-- a.task_status = '33'
-- OR a.task_status = '99'
);-- 插入日志
INSERT INTO t_yh_move_data_log (time, tablename, count)
VALUES
(
NOW(),
't_yh_transport_task',
counts
);IF result_code = 1 THEN
-- 发生异常就回滚反之就提交
ROLLBACK;ELSE
COMMIT;END
IF;END
- mysql 调用函数:定时 call 上面的存储过程。
mysql数据库 ,java 代码巧妙结合提升系统性能。的更多相关文章
- SSM 配合 Mysql 数据库和代码数据源主从分离
大型网站为了软解大量的并发访问,除了在网站实现分布式负载均衡,远远不够.到了数据业务层.数据访问层,如果还是传统的数据结构,或者只是单单靠一台服务器扛,如此多的数据库连接操作,数据库必然会崩溃,数据丢 ...
- 操作MySQL数据库相关代码
注意事项: 1.导入驱动包,如我导的是mysql-connector-java-5.1.26-bin.jar 2.修改下面代码中的用户名和密码 3.其中URL为"jdbc:mysql://数 ...
- Linux自动备份MySQL数据库脚本代码
下面这段Linux的Shell脚本用于每日自动备份MySQL数据库,可通过Linux的crontab每天定时执行 在脚本中可设置需要备份的数据库表清单,并且会将备份文件通过gzip压缩.需要注意的是, ...
- Java连接MySQl数据库实现代码
1. 获取数据库连接和查询代码 package connectionmysql; import java.sql.Connection; import java.sql.DriverManager; ...
- (详细)JAVA使用JDBC连接MySQL数据库(3)-代码部分
欢迎任何形式的转载,但请务必注明出处. 本节主要内容 项目建立 数据库连接 数据库操作 主函数 点击进入推荐博客(必看) 一.项目建立 如图所示:新建Java Project.Package.Clas ...
- 更新MySQL数据库( java.sql.SQLException: No value specified for parameter 1) 异常 解决方法
package com.swift; import java.io.File; import java.sql.Connection; import java.sql.PreparedStatemen ...
- Mysql 数据库 基础代码
-- 创建数据库 CREATE DATABASE book; -- 创建作者表 CREATE TABLE authors( Id int not NULL, -- 作者编号 Fname VARCHAR ...
- Java连接MySQL数据库及简单操作代码
1.Java连接MySQL数据库 Java连接MySql需要下载JDBC驱动MySQL-connector-java-5.0.5.zip(举例,现有新版本).然后将其解压缩到任一目录.我是解压到D盘, ...
- MySQL入门很简单: 15 java访问MySQL数据库
1. 连接数据库 1.1 下载安装驱动 java通过JDBC(Java Database Connectivity,Java数据库连接)来访问MySQL数据库.JDBC的编程接口提供的接口和类与MyS ...
随机推荐
- count
select deptno as 部门,count(*) as 人数from emp group by deptno; --统计各个部门的人数
- Java装箱的 " == " 的问题
装箱和拆箱 packagecom.xzj.Test; /* * @ author thisxzj * @ create 2019-02-25 10:56 */ publicclassBase{ ...
- JS判断页面是在浏览器还是微信打开
一.Navigator对象 1.获取用户的浏览器信息. let ua = navigator.userAgent.toLowerCase(); 打印一下ua的结果: Mozilla/5.0 (Maci ...
- 【模板】最长公共子序列(LCS)。
看过好多人的博客,感觉要么是太复杂要么就是太不容易理解. 那就亲自动手写一个通俗易懂的. 先定义两个数组,第一个数组为主,用第二个数组来匹配第一个,看能有多少可以对应上的. 所以,其实第一个数组的内容 ...
- 第一天学JAVA,下载JDK,配置JAVA环境变量!!!
步骤一:下载JDK https://www.oracle.com 我们首先进入到这个网站下载我们运行JAVA的所必须的JDK 进入到这个网站按照图示进入到下一个页面 因为刚学JAVA,我们的JDK版本 ...
- 【Android手机测试】OOM
当大多数应用程序都消耗完自己的内存的时候,因为这些应用程序的内存需求加起来超出了物理内存(包括swap)的容量,内核(OOM killer)必须杀掉一些进程才能腾出空间保障系统正常运行 Linux内核 ...
- 2018-2019-2 20165221 【网络对抗技术】-- Exp6 信息搜集与漏洞扫描
2018-2019-2 20165221 [网络对抗技术]-- Exp6 信息搜集与漏洞扫描 目录 1. 实践目标 2. 实践内容 3. 各种搜索技巧的应用 a. 搜索网址的目录结构 b.使用IP路由 ...
- Win10如何彻底禁用小娜?彻底禁用小娜的方法
原文地址:https://www.cnblogs.com/zhuimengle/p/5949152.html 小娜是Win10系统中的一款强大功能,有了它,我们对电脑的操作将更加方便.Win10系统有 ...
- nginx unit PHP
2018-12-26 14:20:33 星期三 综述: nginx unit php 的关系: nginx -> 转发请求到 8300端口 -> unit 转发 8300 收到的请求 -& ...
- 【python】【logging】python日志模块logging常用功能
logging模块:应用程序的灵活事件日志系统,可以打印并自定义日志内容 logging.getLogger 创建一个log对象 >>> log1=logging.getLogger ...