定时任务实时抓取数据将查询的数据实时更新进表里,对于表里有的数据现在查询的数据还有那就更新,如果之前没有现在有数据那就插入,如果之前有现在没有那就删除,使用java语言使用tk-mybatis使用postgresql

时间: 2024-02-21 11:00:10 浏览: 24
你可以使用tk-mybatis的Mapper接口和注解来实现这个功能,具体步骤如下: 1. 定义一个实体类,用于存储要更新的数据。示例代码如下: ``` public class DataEntity { private Long id; private String col1; private String col2; // 省略getter和setter方法 } ``` 2. 在Mapper接口中定义三个方法,分别用于插入、更新和删除数据。示例代码如下: ``` public interface DataMapper extends Mapper<DataEntity> { @InsertProvider(type = DataSqlProvider.class, method = "insertBatch") void insertBatch(List<DataEntity> dataList); @UpdateProvider(type = DataSqlProvider.class, method = "updateBatch") void updateBatch(List<DataEntity> dataList); @DeleteProvider(type = DataSqlProvider.class, method = "deleteBatch") void deleteBatch(List<Long> idList); } ``` 3. 在DataSqlProvider类中编写动态SQL语句,根据数据是否存在进行相应的操作。示例代码如下: ``` public class DataSqlProvider { public String insertBatch(Map<String, Object> paramMap) { List<DataEntity> dataList = (List<DataEntity>) paramMap.get("list"); StringBuilder sqlBuilder = new StringBuilder(); sqlBuilder.append("INSERT INTO table_name (id, col1, col2) VALUES "); for (DataEntity data : dataList) { sqlBuilder.append("(") .append(data.getId()).append(", ") .append("'").append(data.getCol1()).append("', ") .append("'").append(data.getCol2()).append("'),"); } sqlBuilder.deleteCharAt(sqlBuilder.length() - 1); return sqlBuilder.toString(); } public String updateBatch(Map<String, Object> paramMap) { List<DataEntity> dataList = (List<DataEntity>) paramMap.get("list"); StringBuilder sqlBuilder = new StringBuilder(); sqlBuilder.append("<foreach collection=\"list\" item=\"data\" separator=\";\">") .append("UPDATE table_name SET ") .append("col1 = #{data.col1}, ") .append("col2 = #{data.col2} ") .append("WHERE id = #{data.id}") .append("</foreach>"); return sqlBuilder.toString(); } public String deleteBatch(Map<String, Object> paramMap) { List<Long> idList = (List<Long>) paramMap.get("list"); StringBuilder sqlBuilder = new StringBuilder(); sqlBuilder.append("DELETE FROM table_name WHERE id NOT IN (") .append("<foreach collection=\"list\" item=\"id\" separator=\",\">") .append("#{id}") .append("</foreach>") .append(")"); return sqlBuilder.toString(); } } ``` 4. 在Java代码中调用Mapper接口的方法,将List传入Mapper中执行即可。示例代码如下: ``` @Autowired private DataMapper dataMapper; public void updateData(List<DataEntity> dataList) { List<Long> idList = dataList.stream().map(DataEntity::getId).collect(Collectors.toList()); List<DataEntity> existingDataList = dataMapper.selectByIdList(idList); List<DataEntity> newDataList = new ArrayList<>(); for (DataEntity data : dataList) { boolean exists = false; for (DataEntity existingData : existingDataList) { if (existingData.getId().equals(data.getId())) { exists = true; if (!existingData.equals(data)) { dataMapper.updateByPrimaryKeySelective(data); } break; } } if (!exists) { newDataList.add(data); } } dataMapper.insertBatch(newDataList); dataMapper.deleteBatch(idList); } ``` 注意事项: - 实体类、Mapper接口和SQL语句需要根据实际情况进行修改,如有多个字段需要更新或插入,需要在实体类、Mapper接口和SQL语句中添加相应的字段。 - 插入操作使用的是批量插入,可以提高插入效率。 - 更新操作使用的是selectByIdList方法查询表中已有的数据,如果数据量很大可能会影响查询效率。 - 删除操作使用的是NOT IN语句,将id不在dataList中的数据删除。

相关推荐

最新推荐

recommend-type

C#使用Selenium+PhantomJS抓取数据

本文主要介绍了C#使用Selenium+PhantomJS抓取数据的方法步骤,具有很好的参考价值,下面跟着小编一起来看下吧
recommend-type

PHP使用Curl实现模拟登录及抓取数据功能示例

本文实例讲述了PHP使用Curl实现模拟登录及抓取数据功能。...(5)另外要需要知道要抓取的数据所在的地址。 2. 获取cookie并存储(针对使用cookie文件的网站): $login_url = 'http://www.xxxxx';
recommend-type

Python实现并行抓取整站40万条房价数据(可更换抓取城市)

本文主要是以房价网房价信息爬虫为例,对Python实现整站40万条房价数据并行抓取(可更换抓取城市)的方法进行分析介绍。需要的朋友一起来看下吧
recommend-type

java抓取网页数据获取网页中所有的链接实例分享

java抓取网页数据获取网页中所有的链接实例分享,使用方法,只要实例化HtmlParser时传入网页地址就可以了
recommend-type

Python学习笔记之抓取某只基金历史净值数据实战案例

主要介绍了Python学习笔记之抓取某只基金历史净值数据案例,结合具体实例形式分析了Python基于selenium库的数据抓取及mysql交互相关实现技巧,需要的朋友可以参考下
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

Redis验证与连接:快速连接Redis服务器指南

![Redis验证与连接:快速连接Redis服务器指南](https://img-blog.csdnimg.cn/20200905155530592.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzMzNTg5NTEw,size_16,color_FFFFFF,t_70) # 1. Redis验证与连接概述 Redis是一个开源的、内存中的数据结构存储系统,它使用键值对来存储数据。为了确保数据的安全和完整性,Redis提供了多
recommend-type

gunicorn -k geventwebsocket.gunicorn.workers.GeventWebSocketWorker app:app 报错 ModuleNotFoundError: No module named 'geventwebsocket' ]

这个报错是因为在你的环境中没有安装 `geventwebsocket` 模块,可以使用下面的命令来安装: ``` pip install gevent-websocket ``` 安装完成后再次运行 `gunicorn -k geventwebsocket.gunicorn.workers.GeventWebSocketWorker app:app` 就不会出现这个报错了。
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。