sql逻辑优化

1.分页 通常使用每页条数及第一页作为参数 开发接口

java 复制代码
@GetMapping("/querySystemList")
public List<SystemAduit> querySystemList(@RequestParam("keyword") String keyword,
                                         @RequestParam(name = "offset", defaultValue = "0") int offset,
                                         @RequestParam(name = "limit", defaultValue = "20") int limit){
     HashMap<String,Object> params=new HashMap<>();
     if(StringUtils.isNotEmpty(keyword)){
         params.put("keyword",keyword);
     }
     params.put("limit",limit);
     params.put("offset",offset);
     List<SystemAduit> systemAduits = systemAduitMapper.querySystemList(params);
     return systemAduits;
}

SQL如下:

XML 复制代码
<select id="querySystemList" resultMap="systemAduitMap" parameterType="java.util.HashMap">
	select * from system_aduit
	where 1=1
	<if test="keyword!=null and keyword!=''">			
        and opertion  like concat('%',#{keyword},'%')
	</if>
	limit #{offset},#{limit}
</select>

但是当数据量特别大的时候,查询速度会减慢很多,limit 10000,10 查询速度较慢

于是,在查询下一页数据时 将上一页的最大值当成参数作为查询条件进行查询

java 复制代码
@GetMapping("/queryListByParams")
public List<SystemAduit> queryListByParams(@RequestParam("keyword") String keyword,
                                           @RequestParam("maxTime") String maxTime,
                                           @RequestParam("limit") int limit){
     HashMap<String,Object> params=new HashMap<>();
     if(StringUtils.isNotEmpty(keyword)){
          params.put("keyword",keyword);
     }
     if(StringUtils.isNotEmpty(maxTime)){
          params.put("maxTime",maxTime);
     }
     params.put("limit",limit);
     List<SystemAduit> systemAduits = systemAduitMapper.queryListByParams(params);
     return systemAduits;
}

SQL如下:

XML 复制代码
<select id="queryListByParams" resultMap="systemAduitMap" parameterType="java.util.HashMap">
	select * from system_aduit
	where 1=1
	<if test="keyword!=null and keyword!=''">
		and opertion  like concat('%',#{keyword},'%')
	</if>
	<if test="maxTime!=null and maxTime!=''">
		and create_time  &gt; #{maxTime}
	</if>
	limit #{limit}
</select>

当数据量特别大的话,查询的速度 还是比较稳定的。

最近接触的项目,若是数据量很大时,则限制查询日期为一个月;或者定期将数据进行备份到另一个数据库,后查询该库;

有好的建议,欢迎大家评论!

相关推荐
极限实验室3 小时前
APM(一):Skywalking 与 Easyearch 集成
数据库·云原生
饕餮争锋3 小时前
SQL条件中WHERE 1=1 的功能
数据库·sql
玄斎4 小时前
MySQL 单表操作通关指南:建库 / 建表 / 插入 / 增删改查
运维·服务器·数据库·学习·程序人生·mysql·oracle
编织幻境的妖4 小时前
SQL查询连续登录用户方法详解
java·数据库·sql
编程小Y4 小时前
MySQL 与 MCP 集成全解析(核心原理 + 实战步骤 + 应用场景)
数据库·mysql·adb
零度@5 小时前
SQL 调优全解:从 20 秒到 200 ms 的 6 步实战笔记(附脚本)
数据库·笔记·sql
Miss_Chenzr5 小时前
Springboot优卖电商系统s7zmj(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
lvbinemail5 小时前
Grafana模板自动复制图表
数据库·mysql·zabbix·grafana·监控
Miss_Chenzr5 小时前
Springboot旅游景区管理系统9fu3n(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·旅游
小虾米vivian6 小时前
dmetl5 运行失败,提示违反协议?
数据库·达梦数据库