mybatis小记

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)


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MybatisMybatis Plus是两个在Java开发中常用的持久层框架。Mybatis是一个优秀的持久层框架,它通过XML配置文件或注解的方式实现了数据库的操作,同时提供了强大的SQL映射功能。而Mybatis Plus是在Mybatis的基础上进行二次封装的框架,它简化了Mybatis的使用,提供了更加便捷的CRUD操作方法和更加灵活的查询方式,同时还集成了一些常用的功能模块,如分页、逻辑删除等。 在Spring Boot中整合MybatisMybatis Plus可以通过引入相应的依赖和配置文件来实现。可以参考示例代码中的Spring Boot项目,其中包含了整合MybatisMybatis Plus的配置和示例代码。 在配置文件中,可以通过配置MybatisPlusConfig来配置Mybatis Plus的一些参数和功能,例如分页插件、逻辑删除插件等。同时,需要将Mybatis的XML文件放置在resources目录下的mapper文件夹中,以供Mybatis进行SQL映射。 总之,MybatisMybatis Plus都是非常常用的持久层框架,它们可以帮助开发者简化数据库操作,提高开发效率。在Spring Boot中整合它们可以通过引入依赖和配置文件来实现。希望以上信息对您有所帮助。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SpringBoot+Mybatis+Mybatis Plus+Shiro实现一个简单的项目架构](https://download.csdn.net/download/feritylamb/11490995)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [spring boot整合mybatis+mybatis-plus的示例代码](https://download.csdn.net/download/weixin_38506798/12764240)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [spring boot整合mybatis+mybatis-plus](https://blog.csdn.net/aotun7642/article/details/102437856)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值