框架-MyBatis

1 什么是MyBatis

MyBatis是一个优秀的持久层框架,它对JDBC访问数据库的过程进行了封装,简化了JDBC代码,解决JDBC将结果集封装为Java对象的麻烦

2 MyBatis架构图

在这里插入图片描述

  1. mybatis-config.xml是Mybatis的核心配置文件,通过其中的配置可以生成SqlSessionFactory,也就是SqlSession工厂
  2. 基于SqlSessionFactory可以生成SqlSession对象
  3. SqlSession可以发送SQL去执行,并返回结果,类似于JDBC中的Connection对象
  4. Executor是SqlSession底层的对象,用于执行SQL语句
  5. MapperStatement对象也是SqlSession底层的对象,用于接收输入映射(SQL语句中的参数),以及做输出映射(即将SQL查询的结果映射成相应的结果)

3 MyBatis的优势

  1. Mybatis对JDBC对了封装,可以简化JDBC代码;
  2. Mybatis自身支持连接池(也可以配置其他的连接池),因此可以提高程序的效率;
  3. Mybatis是将SQL配置在mapper文件中,修改SQL只是修改配置文件,类不需要重新编译。
  4. 对查询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中的占位符

  1. #{}占位符
  • 当#{}占位符是为字符串或者日期类型的值进行占位时,在参数值传过来替换占位符的同时,会进行转义处理
  • #{}占位符如果只有一个的话,可以直接将参数传给SQL语句,不用封装到pojo对象或map集合
  1. ${}占位符
  • 为SQL片段(字符串)进行占位,将传过来的SQL片段直接拼接在 ${} 占位符所在的位置,不会进行任何的转义处理。可能会引发SQL注入攻击问题
  • 在传递 ${} 对应的值时,即使只有一个参数,也需要将值存入map集合或pojo对象中

5 Mapper接口开发

  1. 创建一个接口,接口的全限定类名和mapper文件的namespace值要相同
  2. mapper文件中每条要执行的SQL语句,在接口中要添加一个对应的方法,并且接口中的方法名和SQL标签上的id值相同
  3. Mapper接口中方法接收的参数类型,和mapper.xml中定义的sql的接收的参数类型要相同
  4. 接口中方法的返回值类型和SQL标签上的resultType即返回值类型相同(如果方法返回值是集合,resultType只需要指定集合中的泛型)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值