目录
mybatis的接口绑定方法
mybatis实现了接口绑定,使用会更加方便,接口绑定:mybatis
中任意定义接口,然后把接口里面的方法和SQL语句绑定,就可以直接调用接口方法使用。
接口绑定方式:
- 通过注解绑定,直接在方法上面加上@Select ,@Update等注解,在注解里包含SQL绑定;
- 通过XML里面SQL绑定,需要在xml配置文件里的namespace必须指定接口的全限定名
1. XML方法的方法
1.1 创建接口文件
public interface StudentMapper {
//通过id来查询某一个学生信息
public Student selectStudentById(Integer id);
}
1.2 创建mapper.xml配置文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--命令空间 一般指定对应的接口的全路径-->
<mapper namespace="com.jing.mapper.StudentMapper">
<select id="selectStudentById" parameterType="int" resultType="student">
select * from student where SID = #{id}
</select>
1.3 配置映射路径
<!--映射文件引入-->
<mappers>
<!--resource方式: 指定单个映射文件-->
<mapper resource="mapper/StudentMapper.xml"/>
</mappers>
注意:编写mapper.java 接口和mapper.xml配置文件需要遵循一些开发规范,mybatis才能自动生成mapper接口的代理类对象
开发规范:
- 在mapper.xml配置文件中namespace等于接口的全路径;
- 使用的Statement的id属性值需要和接口中的方法名保持一致;
- 接口文件方法参数类型和mapper.xml文件中parameterType指定类型一致;
- 接口文件方法的返回值类型和mapper.xml中的resultType指定的类型一致。
2. 注解形式
注解方法SQL直接写在接口上。
优点:比较简单,效率更高一些
缺点:当SQL发生改变都需要重新编译代码
mybatis的注解中,基本注解@Select 、@Insert()、@Update、@Delete
@Insert
@Options(useGeneratedKeys = true)//自增
@Insert("insert into jing1(id,age) values(#{id},#{age})")
int insertJing1(Annotation jing1);
在方法上直接添加@Insert注解,将sql语句直接写在注解中。如果在插入操作需要添加自增主键等操作时,需要使用@Options注解,该注解中包含useGeneratedKeys等操作。
和xml配置对比
注意:自增时,前提在数据库必须要支持,设置允许自增操作。
@Select
@Select("select * from jing1 where id = #{id}")
Annotation selectJing1ById(Integer id);
查询操作使用select注解直接在注解内给定SQL语句,如果数据库字段和映射pojo类属性名一致,则如上使用。如果数据库字段和映射pojo类属性名不一致,也可以使用@results显性指定映射关系。
@Results注解对应XML中的ResultMap标签
@Result对应xml中的result标签(在result注解中后id=true表明id 属性是主键)
3. 输出映射
输出类型:resultType和resultMap
使用resultType,数据库的字段名和pojo类的属性名保持一致才能映射成功,如果字段名和属性名完全不一致,则不会创建出自定义对象。如果字段名和属性名部分一致,会创建出自定义对象,对相同的字段和属性会完成映射。
使用resultMap可以显性指定字段名和属性名的映射关系,不管输出是单个对象(selectOne)还是多个结果集(selectList),在mapper.xml中resultType或者resultMap的类型是一样的,不一样的是mapper.java 接口文件中返回值类型不一样。
输出的是单个自定义的对象,方法返回单个对象的类型;输出的是多个对象的结果集,方法的返回是List<Object>。
4. 多个接口参数
public int updateNameById(Integer id, String name);
如果直接在接口中传递多个参数时,在sql执行过程中会抛出以下错误:
注意:mybatis中多个参数时,mybatis有效的参数名只能是0,1,param1,param2等,才可以识别,当传递参数命名为其他的id或name时则不能识别,要么改成0,1等mybatis可识别的参数,但这样不方便代码查看,显然是无意义的。
解决办法:可以在传递的多个参数上添加注解@Param注解,mybatis就会自动封装成Map类型的数据,Param内的名称作为key,传递的数据作为值,在SQL执行过程中会通过入参来做解析
int updateNameById(@Param("id") Integer id,@Param("name") String name);