mybatis mapper xml文件的导入方式和查询方式

mybatis mapper xml文件的导入方式和查询方式

ssm框架 Mybatis

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;
    }
}

传入一个参数

  1. java基本类型

    在映射文件中:

    <select id="queryByID" resultType="com.weno.pojo.Girl">
        select * from girl where id=#{id};
    </select>

在Java文件中,映射方法:

Girl queryByID(int id);

传入多个参数

  1. 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);
  1. 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);
  1. @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了。

至于使用哪一个,那就看具体情况,哪一个方便就使用哪一个了。

原文地址:https://www.cnblogs.com/xiaohuiduan/p/9865144.html

时间: 2024-10-14 05:23:59

mybatis mapper xml文件的导入方式和查询方式的相关文章

MyBatis Mapper.xml文件中 $和#的区别

MyBatis Mapper.xml文件中 $和#的区别 网上有很多,总之,简略的写一下,作为备忘.例子中假设参数名为 paramName,类型为 VARCHAR . 1.优先使用#{paramName,jdbcType=VARCHAR} 写法,除了可以防止sql注入以外,它还能在参数里含有单引号的时候自动转义, 而${paramName}由于是类似于拼接sql的写法,不具备此功能. 2.注意,使用 #{paramName,jdbcType=VARCHAR} 写法的时候,模糊查询的写法为:'%'

启动项目时,mapper.xml文件没有导入

原因分析:绑定的statement没有发现,原因是只有mapper接口的java文件,没有xml文件 解决方法:需要在pom文件中进行配置 1 <!-- 如果不添加此节点mybatis的mapper.xml文件都会被漏掉. --> 2 <build> 3 <resources> 4 <resource> 5 <directory>src/main/java</directory> 6 <includes> 7 <in

笔记:MyBatis Mapper XML文件详解 - 映射和参数

MyBatis 的真正强大在于它的映射语句,也是它的魔力所在.由于它的异常强大,映射器的 XML 文件就显得相对简单.如果拿它跟具有相同功能的 JDBC 代码进行对比,你会立即发现省掉了将近 95% 的代码.MyBatis 就是针对 SQL 构建的,并且比普通的方法做的更好. SQL 映射文件有很少的几个顶级元素(按照它们应该被定义的顺序): cache – 给定命名空间的缓存配置. cache-ref – 其他命名空间缓存配置的引用. resultMap – 是最复杂也是最强大的元素,用来描述

mybatis Mapper XML 文件

MyBatis 的真正强大在于它的映射语句,也是它的魔力所在.由于它的异常强大,映射器的 XML 文件就显得相对简单.如果拿它跟具有相同功能的 JDBC 代码进行对比,你会立即发现省掉了将近 95% 的代码.MyBatis 就是针对 SQL 构建的,并且比普通的方法做的更好. SQL 映射文件有很少的几个顶级元素(按照它们应该被定义的顺序): cache – 给定命名空间的缓存配置. cache-ref – 其他命名空间缓存配置的引用. resultMap – 是最复杂也是最强大的元素,用来描述

MyBatis Mapper XML 文件 的学习详解

MyBatis 真正的力量是在映射语句中.这里是奇迹发生的地方.对于所有的力量,SQL 映射的 XML 文件是相当的简单.当然如果你将它们和对等功能的 JDBC 代码来比较,你会发现映射文件节省了大约 95%的代码量.MyBatis 的构建就是聚焦于 SQL 的,使其远离于普通的方式. SQL 映射文件有很少的几个顶级元素(按照它们应该被定义的顺序): cache – 配置给定命名空间的缓存. cache-ref – 从其他命名空间引用缓存配置. resultMap – 最复杂,也是最有力量的元

笔记:MyBatis Mapper XML文件详解 - Result Maps

Result Maps(结果集) resultMap 元素是 MyBatis 中最重要最强大的元素.它就是让你远离 90%的需要从结果 集中取出数据的 JDBC 代码的那个东西, 而且在一些情形下允许你做一些 JDBC 不支持的事 情. 事实上, 编写相似于对复杂语句联合映射这些等同的代码, 也许可以跨过上千行的代码. ResultMap 的设计就是简单语句不需要明确的结果映射,而很多复杂语句确实需要描述它们 的关系,你已经看到简单映射语句的示例了,但没有明确的 resultMap.比如: <s

mybatis mapper xml文件配置resultmap时,id行和result行有什么区别?

<resultMap id = "CashInvoiceMap" type="com.dfire.soa.invoice.bo.Invoice">    <id column="id" property="id" />    <result column="order_id" property="orderId" />    <result co

【MyBatis】Mapper XML 文件

Mapper XML文件 MyBatis 的真正强大在于它的映射语句,也是它的魔力所在.由于它的异常强大,映射器的 XML 文件就显得相对简单.如果拿它跟具有相同功能的 JDBC 代码进行对比,你会立即发现省掉了将近 95% 的代码.MyBatis 就是针对 SQL 构建的,并且比普通的方法做的更好. SQL 映射文件有很少的几个顶级元素(按照它们应该被定义的顺序): cache – 给定命名空间的缓存配置. cache-ref – 其他命名空间缓存配置的引用. resultMap – 是最复杂

A query was run and no Result Maps were found for...原来是mapper.xml文件出了问题,是使用MyBatis最常见的一种错误

今天遇到一个问题,原来是mapper.xml文件出了问题,是使用MyBatis最常见的一种错误 报错的结果是这样的: A query was run and no Result Maps were found for the Mapped Statement 'cn.zrgk.dao.RoleMapper.getRoleList'. It's likely that neither a Result Type nor a Result Map was specified. org.apache.