1.复杂查询
示例:SELECT ?,?,? FROM ? WHERE ?=?
1.1复杂查询的条件传递
1.1.1.这里内容主要在于mapper.xml文件的配置编写和mapper类的代码编写。
mapper.xml中,select标签如下。
<select id="methodNameInMapperJava" resultMap="IdOfResultMapLabel">
SELECT ${columsString} FROM ${tableName} WHERE ${conditionKeys}=#{condition}
</select>
mapper.java定义的对应方法如下
methodNameInMapperJava(@Param("columsString")String columsString,@Param("tableName") String tableName,
@Param("conditionKeys") String conditionKeys,@Param("conditionKeys"), String @Param("condition") String condition);
columsString可以是字符串例如:colums1,colums2.colums3,这样的不确定的一个或者多个列名。
由此引出结果返回的类型,由于查询的内容不确定,所以无法使用确定的pojo去接收查询的结果。
因此使用Map代替pojo类接收查询结果。
1.2复杂查询接收结果
mapper.xml文件的resultMap标签如下:
<resultMap id="IdOfResultMapLabel" type="java.util.Map">
<result column="Update_Date" property="updateDate" jdbcType="TIMESTAMP" />
<result column="Data1" property="data1" jdbcType="DECIMAL" />
<result column="Data2" property="data2" jdbcType="DECIMAL" />
<result column="Data3" property="data3" jdbcType="VARCHAR" />
</resultMap>
Mapper类定义的方法返回类型为
List<HashMap<String,Object>>
2.关于结果的顺序。
2.1 按照固定的先后顺序。
可以使用resultMap来定义接收的结果集和顺序。
例如:
<resultMap id="BaseResultMap" type="com.ryzh0310.pojo.Data_History_Out">
<result column="Data1" property="data1" jdbcType="VARCHAR" />
<result column="Data2" property="data2" jdbcType="VARCHAR" />
<result column="Data3" property="data3" jdbcType="VARCHAR" />
<result column="Data4" property="data4" jdbcType="VARCHAR" />
<result column="Data5" property="data5" jdbcType="VARCHAR" />
<result column="Data6" property="data6" jdbcType="VARCHAR" />
<result column="Data7" property="data7" jdbcType="VARCHAR" />
<result column="Data8" property="data8" jdbcType="VARCHAR" />
<result column="Data9" property="data9" jdbcType="VARCHAR" />
<result column="Data10" property="data10" jdbcType="VARCHAR" />
</resultMap>
当查询语句为
select Data10,Data9,Data8,Data7 from _tablename
查询结果顺序为:(Data7,Data8,Data9,Data10)
2.2 按照查询顺序排序
如果要按照查询时的顺序显示结果,需要用LinkedHashMap接收结果。 <select id="selectData" resultType="java.util.LinkedHashMap">
select Data10,Data9,Data8,Data7 from _tablename
</select>
使用2.1的查询语句,查询结果的顺序为:(Data10,Data9,Data8,Data7)