甲方又提新需求了,虽然心里已经有了解决办法,还是表现得好难的样子,按惯例先bb一通有多复杂,多难实现。
前情提要:
数据库:mysql
数据库框架:mybatis
已经有了两个搜索条件,此时又要新增一个查询条件,查询条件变为三个。但是输入框只有一个,此时三个条件只能选取其中一个。
难点:
因为三个查询条件只能选取其中一个,首先想到的是or查询,但是这样的方法必然很慢,因此想到用 union all
优化or
查询速度。
上代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="me.cf.me.mes.dao.MesItemMapper">
<sql id="allColumns">
id,
create_time,
update_time,
order_no,
car_material_code,
car_material_name,
carseries_code,
model,
short_name
</sql>
<sql id="selectBasePage">
SELECT <include refid="allColumns"/>
FROM epc_mes_item
</sql>
<sql id="selectByCarMaterialCode">
<where>
AND car_material_code = #{map.carMaterialCodeOrOrderNoOrCarseriesCode}
</where>
</sql>
<sql id="selectByOrderNo">
<where>
AND order_no = #{map.carMaterialCodeOrOrderNoOrCarseriesCode}
</where>
</sql>
<sql id="selectByCarseriesCode">
<where>
AND carseries_code = #{map.carMaterialCodeOrOrderNoOrCarseriesCode}
</where>
</sql>
<!--查询总条数-->
<select id="getPageCount" resultType="java.lang.Long">
<choose>
<when test="map.carMaterialCodeOrOrderNoOrCarseriesCode != null and map.carMaterialCodeOrOrderNoOrCarseriesCode !=''">
SELECT COUNT(1) FROM (
<include refid="selectBasePage"/>
<include refid="selectByCarMaterialCode"/>
UNION ALL
<include refid="selectBasePage"/>
<include refid="selectByOrderNo"/>
UNION ALL
<include refid="selectBasePage"/>
<include refid="selectByCarseriesCode"/>
)t
</when>
<otherwise>
SELECT COUNT(1) FROM epc_mes_item
</otherwise>
</choose>
</select>
<!-- 分页 -->
<select id="getPage" resultType="me.cf81.onestep.mes.model.MesItem">
<choose>
<when test="map.carMaterialCodeOrOrderNoOrCarseriesCode != null and map.carMaterialCodeOrOrderNoOrCarseriesCode !=''">
<include refid="selectBasePage"/>
<include refid="selectByCarMaterialCode"/>
UNION ALL
<include refid="selectBasePage"/>
<include refid="selectByOrderNo"/>
UNION ALL
<include refid="selectBasePage"/>
<include refid="selectByCarseriesCode"/>
</when>
<otherwise>
<include refid="selectBasePage"/>
</otherwise>
</choose>
ORDER BY create_time DESC
LIMIT #{pageable.offset}, #{pageable.pageSize}
</select>
</mapper>
这里你首先需要清楚 union
和union all
的用法及区别
三个条件字段需要加上索引,不然效果不明显。
这次改动的遇到的问题的地方在查询分页数量上,并不能简单的直接的count,而是要先根据条件查数据创建临时表,然后统计临时表的数量。
还有一个不知道是否可以优化:在查询分页数量的时候,临时表的字段可以只查询一个,但是我不知道在查询分页的时候会不会用到查分页数量的sql缓存,所以就没有优化