mybatis mapper xml文件的导入方式和查询方式
mybatis mapper xml文件的导入方式和查询方式
mapper与SQLSession的关系
每个基于MyBatis的应用都是以一个SqlSessionFactory的实例为中心的。通过SqlSessionFactory可以获得SQLSession实例,然后在其中完全包含了数据库执行SQL命令所需要的所有方法。
SQLMapper是由一个Java接口和XML文件构成的,给出一定的SQL和映射规则。负责SQL的执行和返回结果。
通过SQLSession获得Mapper映射器接口,然后执行SQL操作。
mapper xml文件的导入方式
根据文件相对地址导入
例如:
<mappers>
<!-- 第一种引入方式 resource引入-->
<mapper resource="com.weno.mapper/GirlMapper.xml"></mapper>
</mappers>
通过包导入
如果有很多个mapper xml文件,一个一个去导入太麻烦了,这时候可以选择导入一个包,将包里面的Java接口文件全部导入。不过需要注意的点:文件名要相似:Girl.java和Girl.xml,同时文件目录结构要一样。
<mappers>
<!--第二种引入方式 通过包去引入-->
<package name="com.weno.mapper"/>
</mappers>
这个是2种最常见的xml文件导入方式。
Mybatis查询方式之参数传递
假如此时有一个Girl数据库表:
| id | name | flower |
|---|---|---|
| 17 | xiaoai1 | rose |
Girl java文件
package com.weno.pojo;
public class Girl {
private int id;
private String name;
private String flower;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getFlower() {
return flower;
}
public void setFlower(String flower) {
this.flower = flower;
}
}
传入一个参数
- java基本类型
在映射文件中:
<select id="queryByID" resultType="com.weno.pojo.Girl">
select * from girl where id=#{id};
</select>
在Java文件中,映射方法:
Girl queryByID(int id);
传入多个参数
- java基本对象
在映射文件中
<select id="queryByGirl" resultType="com.weno.pojo.Girl">
select * from girl where id=#{id};
<!-- 会自动调用getID()函数去获取ID -->
</select>
在Java文件中,映射方法:
Girl queryByID(Girl g);
在测试文件中
Girl g = new Girl();
g.setId(17);
// 可以加多个set
Girl girl = mapper.queryByGirl(g);
- Map传递参数
在映射文件中
<select id="queryByGirl1" resultType="com.weno.pojo.Girl">
select * from girl WHERE id=#{id};
</select>
<!-- 其中id要跟Map里面的key一样 -->
在Java文件中,映射方法:
Girl queryByGirl1(Map<String,Object> map);
在测试文件中
Map<String,Object> map= new HashMap<String, Object>();
map.put("id",17);
// id对应xml文件中的id
Girl girl=mapper.queryByGirl1(map);
- @Param传递参数
在映射文件中
<select id="queryByGirl2" resultType="com.weno.pojo.Girl">
select * from girl WHERE id=#{id} and flower=#{flower};
</select>
在Java文件中,映射方法:
Girl queryByGirl2(int id,String flower);
测试文件
GirlMapper mapper = sqlSession.getMapper(GirlMapper.class);
Girl girl=mapper.queryByGirl2(17,"rose");
如果这时候运行,则会报错
org.apache.ibatis.exceptions.PersistenceException:
### Error querying database. Cause: org.apache.ibatis.binding.BindingException: Parameter 'id' not found. Available parameters are [0, 1, param1, param2]
### Cause: org.apache.ibatis.binding.BindingException: Parameter 'id' not found. Available parameters are [0, 1, param1, param2]
大概意思就是,mapper方法的参数绑定异常。
原因:
这个异常的产生原因是因为,当mapper接口方法有多个参数时,java不会保存行参的记录,java在运行的时候会把方法中的参数(int id,String flower)变成这样:(int arg0,String arg1),这样我们就没有办法去传递多个参数(注意,在多个参数时才会发生)
解决方法:
3.1 将参数映射文件中的参数改为
<select id="queryByGirl2" resultType="com.weno.pojo.Girl">
select * from girl WHERE id=#{0} and flower=#{1};
</select>
或者将参数改为param1和param2
<select id="queryByGirl2" resultType="com.weno.pojo.Girl">
select * from girl WHERE id=#{param1} and flower=#{param2};
</select>
这两个没什么区别,只不过一个是从0开始,有个是从1开始罢了。
3.2 使用@param
尽管上面的的方法能够解决这个问题,但是显而易见,这个不符合程序的设计理念,因为阅读代码的时候没办法马上理解内容。所以可以使用@Param解决这个问题。
映射方法
Girl queryByGirl3(@Param("id") int id,@Param("flower")String flower);
映射文件
<select id="queryByGirl3" resultType="com.weno.pojo.Girl">
select * from girl WHERE id=#{id} and flower=#{flower};
</select>
这样就可以开开心心的使用我的flower了。
至于使用哪一个,那就看具体情况,哪一个方便就使用哪一个了。
mybatis mapper xml文件的导入方式和查询方式的更多相关文章
- MyBatis Mapper.xml文件中 $和#的区别
MyBatis Mapper.xml文件中 $和#的区别 网上有很多,总之,简略的写一下,作为备忘.例子中假设参数名为 paramName,类型为 VARCHAR . 1.优先使用#{paramN ...
- mybatis mapper xml文件配置resultmap时,id行和result行有什么区别?
mybatis mapper xml文件配置resultmap时,id行和result行有什么区别? <resultMap id = "CashInvoiceMap" typ ...
- MyBatis——Mapper XML 文件
Mapper XML 文件 MyBatis 的真正强大在于它的映射语句,也是它的魔力所在.由于它的异常强大,映射器的 XML 文件就显得相对简单.如果拿它跟具有相同功能的 JDBC 代码进行对比,你会 ...
- 启动项目时,mapper.xml文件没有导入
原因分析:绑定的statement没有发现,原因是只有mapper接口的java文件,没有xml文件 解决方法:需要在pom文件中进行配置 <!-- 如果不添加此节点mybatis的mapper ...
- 笔记:MyBatis Mapper XML文件详解 - 映射和参数
MyBatis 的真正强大在于它的映射语句,也是它的魔力所在.由于它的异常强大,映射器的 XML 文件就显得相对简单.如果拿它跟具有相同功能的 JDBC 代码进行对比,你会立即发现省掉了将近 95% ...
- mybatis Mapper XML 文件
MyBatis 的真正强大在于它的映射语句,也是它的魔力所在.由于它的异常强大,映射器的 XML 文件就显得相对简单.如果拿它跟具有相同功能的 JDBC 代码进行对比,你会立即发现省掉了将近 95% ...
- MyBatis Mapper XML 文件 的学习详解
MyBatis 真正的力量是在映射语句中.这里是奇迹发生的地方.对于所有的力量,SQL 映射的 XML 文件是相当的简单.当然如果你将它们和对等功能的 JDBC 代码来比较,你会发现映射文件节省了大约 ...
- 笔记:MyBatis Mapper XML文件详解 - Result Maps
Result Maps(结果集) resultMap 元素是 MyBatis 中最重要最强大的元素.它就是让你远离 90%的需要从结果 集中取出数据的 JDBC 代码的那个东西, 而且在一些情形下允许 ...
- 笔记:MyBatis Mapper XML文件详解 - Cache
缓存(Cache) 从数据库中加载的数据缓存到内存中,是很多应用程序为了提高性能而采取的一贯做法.MyBatis对通过映射的SELECT语句加载的查询结果提供了内建的缓存支持.默认情况下,启用一级缓存 ...
随机推荐
- JPanel JScrollPanel
JPanel 和 JScrollPanel 都属于面板,也是 Swing 中间容器,可以作为容器存放组件,但必须被添加到其他容器中. JPanel 可以聚集一些组件来布局, JScrollPanel ...
- M1卡知识点描述
- C#当中的扩展方法
先说有用的,c#扩展方法结论: 扩展方法能够向现有类型“添加”方法,而无需创建新的派生类型,重新编译或以其他方式修改原始类型.扩展方法必须是静态方法,可以像实例方法一样进行调用.且调用同名中实际定义的 ...
- 跨域访问问题js
您可以通过使用JSONP形式的回调函数来加载其他网域的JSON数据 访问百度的地址解析 返回来省,地区,市 $.getJSON("http://api.map.baidu.com/clou ...
- 进程池、tornado、字体
协程: import grequests from fake_useragent import UserAgent urls=[f'http://bir删d.so/search?page={p ...
- two sum --无脑法
public class Solution { /* * @param numbers: An array of Integer * @param target: target = numbers[i ...
- 方向导数,梯度和梯度下降之BGD,SGD
方向导数和梯度的直观理解,from知乎-马同学: https://www.zhihu.com/question/36301367 BGD,SGD: https://www.cnblogs.com/gu ...
- 第十八节:详解Java抽象类和接口的区别
前言 对于面向对象编程来说,抽象是它的特征之一. 在Java中,实现抽象的机制分两种,一为抽象类,二为接口. 抽象类为abstract class,接口为Interface. 今天来学习一下Java中 ...
- 兼容多数浏览器的js添加收藏夹脚本
浏览器不断发展,js的很多脚本需要跟进才能适应,目前多数代码对新版本浏览器(IE11, Firefox 27)无法适用,特关注跟进. 推荐代码1 适用浏览器:IE11(windows 8.1), Fi ...
- 分布式任务调度系统xxl-job源码探究(二、服务中心)
接下来看下服务端代码 服务端源码 服务端通过管理quartz定时任务组件,分发任务 先从入口看起,由web.xml进入,可以看出,自己编写的代码从applicationcontext-xxl-job- ...