Bootstrap

大数据学习_JdbcTemplate与Mybatis对比

1.JDBC

1.1JDBC概念

JDBC(Java Data Base Connectivity) 是 Java 访问数据库的标准规范.是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。是Java访问数据库的标准规范。

1.2JDBC原理

JDBC是一个接口,驱动(JDBC实现类)是接口的实现,没有驱动将无法完成数据库连接,从而不能操作数据库,每个数据库厂商都需要提供自己的驱动,用来连接自己公司的数据库,也就是说驱动一般都由数据库生成厂商提供。

1.3原始JDBC操作

// 1.注册驱动
// JDBC规范定义驱动接口: java.sql.Driver
// MySql驱动包提供了实现类: com.mysql.jdbc.Driver
Class.forName("com.mysql.jdbc.Driver");

// 2.获取连接
String url = "jdbc:mysql://localhost:3306/db4?characterEncoding=UTF-8";
String username = "root";
String password = "123456";
Connection getConnection(url, username, password)

JDBC规定url的格式由三部分组成,每个部分中间使用冒号分隔。
第一部分是协议 jdbc,这是固定的;
第二部分是子协议,就是数据库名称,连接mysql数据库;
第三部分是由数据库厂商规定的,我们需要了解每个数据库厂商的要求,mysql的第三部分分别由数据库服务器的IP地址(localhost)、端口号(3306),以及要使用的数据库名称组成。
url详解

// 3.获取statemen对象
Statement statement = con.createStatement();

// 4.编写sql语句
String sql = ;

// 5.执行增删改操作,使用executeUpdate
// 返回值是受影响的行数,如果执行DDL(create 、drop 、alter、truncate table等)时返回值是0
int i = statement.executeUpdate(sql);

// 6.执行查询操作,使用executeQuery
// 返回值是一个ResultSet结果对象,接着可通过遍历得到查询结果
ResultSet resultSet = statement.executeQuery(sql);

//7.关闭流
statement.close();
con.close();

1.4步骤总结

  1. 获取驱动(可以省略)
  2. 获取连接
  3. 获取Statement对象
  4. 处理结果集(只在查询时处理)
  5. 释放资源

1.5原生JDBC缺点

  • 数据库连接创建、释放频繁造成系统资源浪费从而影响系统性能
  • sql 语句在代码中硬编码,造成代码不易维护,实际应用 sql 变化的可能较大,sql 变动需要改变java代码。
  • 查询操作时,需要手动将结果集中的数据手动封装到实体中。

2.JdbcTemplate

2.1JdbcTemplate概念

JdbcTemplate是spring框架中提供的一个模板对象,是对原始繁琐的JdbcAPI对象的简单封装。
核心对象:JdbcTemplate jdbcTemplate = new JdbcTemplate(DataSource dataSource);

2.2JdbcTemplate操作数据库

// 1.创建核心对象
JdbcTemplate jdbcTemplate = new JdbcTemplate(JdbcUtils.getDataSource());

// 2.编写sql
String sql = ;

// 3.执行语句
// 增、删、改语句使用update方法
int i =  jdbcTemplate.update(sql,arg..); 
// 单个查询语句语句使用queryForObject方法
Object obj = jdbcTemplate.queryForObject(sql, new BeanPropertyRowMapper<>(Object.class));
// 多个查询语句语句使用query方法
List<Object> list = jdbcTemplate.query(sql, new BeanPropertyRowMapper<>(Object.class));

优点

  • 使用JdbcTemplate可节省大量的冗余代码(创建连接,关闭连接,处理异常),因为JdbcTemplate类会自动处理它。只关注业务逻辑即可。
  • 查询结果自动封装为类对象
  • 简单效率快

缺点

  • 同样sql语句在代码中存在硬编码问题。

3.Mybatis

3.1Mybatis概念

MyBatis是一个优秀的基于ORM的半自动轻量级持久层框架,它对jdbc的操作数据库的过程进行封装,使开发者只需要关注 SQL 本身,而不需要花费精力去处理例如注册驱动、创建connection、创建statement、手动设置参数、结果集检索等jdbc繁杂的过程代码。

3.2Mybatis原理

ORM思想

  • O(对象模型):实体对象,即我们在程序中根据数据库表结构建立的一个个实体javaBean
  • R(关系型数据库的数据结构):关系数据库领域的Relational(建立的数据库表)
  • M(映射):从R(数据库)到O(对象模型)的映射,可通过XML文件映

具体实现

  • 让实体类和数据库表进行一一对应关系
    • 先让实体类和数据库表对应
    • 再让实体类属性和表里面字段对应
  • 不需要直接操作数据库表,直接操作表对应的实体类对象

Mybatis采用ORM思想解决了实体和数据库映射的问题,对jdbc进行了封装,屏蔽了jdbc api底层访问细节,使我们不用与jdbc api 打交道,就可以完成对数据库的持久化操作。

3.3Mybatis操作数据库

Mybatis操作数据库又分为传统开发方式和代理开发方式,区别在于传统开发方式中需要编写接口的实现类,在实现类中去获取会话对象调用方法操作数据库,这样做在实现类中,存在mybatis模板代码重复;且实现类调用方法时,xml中的sql statement会硬编码到java代码中。
代理开发方式解决了这一问题,是现在企业的主流。
下边操作数据库步骤以代理开发方式为例:

1.mybatis配置

  • 编写MyBatis核心文件
    SqlMapConfig.xml,此文件作为mybatis的全局配置文件,配置了mybatis的运行环境等信息(数据源,事物,mapper映射文件)。
  • 编写Mapper映射文件
    mapper.xml文件即sql映射文件,文件中配置了操作数据库的sql语句。此文件需要在SqlMapConfig.xml中加载。
    • Mapper.xml映射文件中的namespace与mapper接口的全限定名相同
    • Mapper接口方法名和Mapper.xml映射文件中定义的每个statement的id相同
    • Mapper接口方法的输入参数类型和mapper.xml映射文件中定义的每个sql的parameterType的类型相同
    • Mapper接口方法的输出参数类型和mapper.xml映射文件中定义的每个sql的resultType的类型相同
    • 规范

2.编写接口

3.编写测试类

// 1.加载核心配置文件
InputStream is = Resources.getResourceAsStream("SqlMapConfig.xml");

// 2.获取SqlSessionFactory工厂对象
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);

// 3.由会话工厂创建SqlSession会话对象
SqlSession sqlSession = sqlSessionFactory.openSession();

// 执行sql
List<User> list = sqlSession.selectList("UserMapper.findAll");

// 释放资源
sqlSession.close();

小结:通过代理开发方式,只需要编写Mapper接口,Mybatis框架会为接口动态生成实现类对象。

3.4Mybatis基于接口代理方式的内部执行原理

代理开发的模式中我们在持久层中只建立了一个接口,通过追踪源码发现,使用的mapper实际上是一个代理对象,是由MapperProxy代理产生的。
在这里插入图片描述
追踪MapperProxy的invoke方法会发现,其最终调用了mapperMethod.execute(sqlSession, args)。
在这里插入图片描述
而进入execute方法会发现,最终工作的还是sqlSession。
在这里插入图片描述

;