1 什么是MyBatis
MyBatis是一个优秀的持久层框架,它对JDBC访问数据库的过程进行了封装,简化了JDBC代码,解决JDBC将结果集封装为Java对象的麻烦
2 MyBatis架构图
- mybatis-config.xml是Mybatis的核心配置文件,通过其中的配置可以生成SqlSessionFactory,也就是SqlSession工厂
- 基于SqlSessionFactory可以生成SqlSession对象
- SqlSession可以发送SQL去执行,并返回结果,类似于JDBC中的Connection对象
- Executor是SqlSession底层的对象,用于执行SQL语句
- MapperStatement对象也是SqlSession底层的对象,用于接收输入映射(SQL语句中的参数),以及做输出映射(即将SQL查询的结果映射成相应的结果)
3 MyBatis的优势
- Mybatis对JDBC对了封装,可以简化JDBC代码;
- Mybatis自身支持连接池(也可以配置其他的连接池),因此可以提高程序的效率;
- Mybatis是将SQL配置在mapper文件中,修改SQL只是修改配置文件,类不需要重新编译。
- 对查询SQL执行后返回的ResultSet对象,Mybatis会帮我们处理,转换成Java对象。
4 MyBatis的代码实现
//1.读取mybatis的核心配置文件(mybatis-config.xml)
InputStream in = Resources.getResourceAsStream("mybatis-config.xml");
//2.通过配置信息获取一个SqlSessionFactory工厂对象
SqlSessionFactory fac = new SqlSessionFactoryBuilder().build( in );
//3.通过工厂获取一个SqlSession对象
SqlSession session = fac.openSession();
//4.通过namespace+id找到要执行的sql语句并执行sql语句
List<Emp> list = session.selectList("EmpMapper.findAll");
//5.输出结果
for(Emp e : list) {
System.out.println( e );
}
4 MyBatis中的占位符
- #{}占位符
- 当#{}占位符是为字符串或者日期类型的值进行占位时,在参数值传过来替换占位符的同时,会进行转义处理
- #{}占位符如果只有一个的话,可以直接将参数传给SQL语句,不用封装到pojo对象或map集合
- ${}占位符
- 为SQL片段(字符串)进行占位,将传过来的SQL片段直接拼接在 ${} 占位符所在的位置,不会进行任何的转义处理。可能会引发SQL注入攻击问题
- 在传递 ${} 对应的值时,即使只有一个参数,也需要将值存入map集合或pojo对象中
5 Mapper接口开发
- 创建一个接口,接口的全限定类名和mapper文件的namespace值要相同
- mapper文件中每条要执行的SQL语句,在接口中要添加一个对应的方法,并且接口中的方法名和SQL标签上的id值相同
- Mapper接口中方法接收的参数类型,和mapper.xml中定义的sql的接收的参数类型要相同
- 接口中方法的返回值类型和SQL标签上的resultType即返回值类型相同(如果方法返回值是集合,resultType只需要指定集合中的泛型)