MyBatis Mapper XML文件详解 - 映射和参数 ——学习


MyBatis 的真正强大在于它的映射语句,也是它的魔力所在。由于它的异常强大,映射器的 XML 文件就显得相对简单。如果拿它跟具有相同功能的 JDBC 代码进行对比,你会立即发现省掉了将近 95% 的代码。MyBatis 就是针对 SQL 构建的,并且比普通的方法做的更好。 


1、select(查询) 

查询语句是 MyBatis 中最常用的元素之一,光能把数据存到数据库中价值并不大,如果还能重新取出来才有用,多数应用也都是查询比修改要频繁。对每个插入、更新或删除操作,通常对应多个查询操作。这是 MyBatis 的基本原则之一,也是将焦点和努力放到查询和结果映射的原因。简单查询的 select 元素是非常简单的。比如: 

 


这个语句被称作 selectPerson,接受一个 int(或 Integer)类型的参数,并返回一个 HashMap 类型的对象,其中的键是列名,值便是结果行中的对应值。 

注意参数符号: #{id} 

这就告诉 MyBatis 创建一个预处理语句参数,通过 JDBC,这样的一个参数在 SQL 中会由一个"?"来标识,并被传递到一个新的预处理语句中,就像这样: 


String selectPerson = "SELECT * FROM PERSON WHERE ID=?"; 
    PreparedStatement ps = conn.prepareStatement(selectPerson); 
    ps.setInt(1,id); 


当然,这需要很多单独的 JDBC 的代码来提取结果并将它们映射到对象实例中,这就是 MyBatis 节省你时间的地方。


select 元素有很多属性允许你配置,来决定每条语句的作用细节:

MyBatis Mapper XML文件详解 - 映射和参数 ——学习_第1张图片

MyBatis Mapper XML文件详解 - 映射和参数 ——学习_第2张图片


2、Sql

这个元素可以被用来定义可重用的 SQL 代码段,可以包含在其他语句中。它可以被静态地(在加载参数) 参数化. 不同的属性值通过包含的实例变化.,比如: 

 ${alias}.id,${alias}.username,${alias}.password  

这个 SQL 片段可以被包含在其他语句中,例如: 

 

属性值可以用于包含的refid属性或者包含的字句里面的属性值,例如: 

 
    ${prefix}Table 
 
 
    from 
         
 
 


3、参数(Parameters)


前面的所有语句中你所见到的都是简单参数的例子,实际上参数是 MyBatis 非常强大的元素,对于简单的做法,大概 90% 的情况参数都很少,比如: 

 
    
上面的这个示例说明了一个非常简单的命名参数映射。参数类型被设置为 int,这样这个参数就可以被设置成任何内容。原生的类型或简单数据类型(比如整型和字符串)因为没有相关属性,它会完全用参数值来替代。然而,如果传入一个复杂的对象,行为就会有一点不同了。比如: 

 
     insert into users (id, username, password) 
     values (#{id}, #{username}, #{password}) 
     

如果 User 类型的参数对象传递到了语句中,id、username 和 password 属性将会被查找,然后将它们的值传入预处理语句的参数中。 



4、多参数传递

MyBatis中的映射语句有一个parameterType属性来制定输入参数的类型。如果我们想给映射语句传入多个参数的话,我们可以将所有的输入参数放到HashMap中,将HashMap传递给映射语句。MyBatis 还提供了另外一种传递多个输入参数给映射语句的方法。假设我们想通过给定的name和email信息查找学生信息,定义查询接口如下: 

Public interface StudentMapper 
{ 
        List findAllStudentsByNameEmail(String name, String email); 
} 

MyBatis 支持将多个输入参数传递给映射语句,并以#{param}的语法形式引用它们: 

 

这里#{param1}引用第一个参数name,而#{param2}引用了第二个参数email 


还可以使用 @Param 注解来给参数命名,定义查询接口如下: 

Public interface StudentMapper 
{ 
        List findAllStudentsByNameEmail(@Param("name") String name, @Param("email") String email); 
}
 
MyBatis 配置文件可以直接使用命名的参数,如下配置: 

 




你可能感兴趣的:(♫,IT之路,------【Mybatis】)