大数据学习_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),以及要使用的数据库名称组成。
// 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步骤总结
- 获取驱动(可以省略)
- 获取连接
- 获取Statement对象
- 处理结果集(只在查询时处理)
- 释放资源
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。