MyBatis-4
成员代码块
构造代码块:
直接在类中定义且没有加static关键字的代码块称为{}构造代码块。构造代码块在创建对象时被调用,每次创建对象都会被调用,并且构造代码块的执行次序优先于类构造函数。
//eg:
new SQL(){
{
SELECT("*");
FROM("student");
} // 成员代码块儿, 构造代码块儿
};
静态代码块:
在java中使用static关键字声明的代码块。静态块用于初始化类,为类的属性初始化。每个静态代码块只会执行一次。由于JVM在加载类时会执行静态代码块,所以静态代码块先于主方法执行。
如果类中包含多个静态代码块,那么将按照"先定义的代码先执行,后定义的代码后执行"。
注意:
1 、静态代码块不能存在于任何方法体内。
2 、静态代码块不能直接访问静态实例变量和实例方法,需要通过类的实例对象来访问。
SQL构建器
@SelectProvider(type = ReturnSql.class , method = "getSelectAll")
- @SelectProvider
- type:指定提供sql的功能类
- method:指定调用功能类的哪一个方法
sql构建器使用步骤
- 构建sql构建类
- 编写—方法,返回值为String
- 在原本注解开发的地方将原有的@XXX注解改为@XXProvider注解
- type参数指定构建类
- method指定对应sql的方法
MyBatis整合工程
-
导包,mybaitis+mysql
- 将mybatis的jar拷贝到WEB-INF/lib
-
拷贝核心配置文件(log4j.properties、MyBatisConfig.xml)
- 到src目录下面
- 修改加载的配置文件(jdbc.properties修改为config.properties)
- 确认映射配置文件加载是否正确(Mappers标签)
-
接口文件(添加对应注解)
-
给接口文件添加对应sql
//查询所有学生信息 @Select("SELECT * FROM student") //条件查询,根据id获取学生信息 @Select("SELECT * FROM student WHERE sid=#{sid}") //新增学生信息 @Insert("INSERT INTO student VALUES (#{sid},#{name},#{age},#{birthday})") //修改学生信息 @Delete("DELETE FROM student WHERE sid=#{sid}")
-
-
service层调用dao层的接口代理实现
- 加载配置文件获取SQLSession
- 拿到Mapper代理实现类调用对应方法