内容简介:解决方法:通过配置文件解决配置信息硬编码问题解决方法:通过连接池解决频繁创建释放问题解决方法:通过配置文件解决SQL语句和参数问题
1.1 传统的JDBC实现
public static void main(String[] args) { Connection connetion = null; PreparedStatement preparedStatement = null; ResultSet resultSet = null; try{ //加载数据库驱动 Class.forName("com.mysql.jdbc.Driver"); connetion = DriverManager.getConnetion("jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8","root","root"); //定义 SQL 语句 String sql = "Select * from user where username = ?"; //获取预处理statement preparedStatement = connection.preparedStatement(sql); preparedStatement.setString(1,"zbc"); resultSet = preparedStatement.executeQuery(); while (resultSet.next()) { int id = resultSet.getInt("id"); String userName = resultSet.getString("username"); //封装 User user = new User(); user.setId(id); user.setUserName(userName) } }catch (Excetption e) { e.printStatckTrace(); } finally { //释放资源 } }
1.2 存在的问题与分析
- 数据库配置存在硬编码问题
解决方法:通过配置文件解决配置信息硬编码问题
- 频繁创建释放数据库连接
解决方法:通过连接池解决频繁创建释放问题
- SQl语句、参数、获取结果集参数均存在硬编码问题
解决方法:通过配置文件解决SQL语句和参数问题
- 返回结果需要手动封装,较为繁琐
解决方法:通过反射解决集合
1.3 Mybatis简介 官网
Mybatis是一款优秀的基于ORM的半自动轻量级持久框架,它支持定制化SQL、存储过程以及高级映射。Mybatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。Mybatis可以使用简单的XML或注解来配置和映射原生类型、接口和 Java 的POJO(Plain Old Java Objects,普通老式Java对象)为数据库中的记录。
1.4 工作原理
- 加载mybatis-config.xml配置文件(数据源,mapper文件以及相关的其他文件),
- 通过SqlSessionFactoryBuilder.build()(用建造者模式)来解析mybatis-config.xml文件,解析的数据保存到configuration对象中
- SqlSessionFactory通过configuration对象来创建SqlSession,然后通过SqlSession进行CURD和事务提交的操作。(创建sqlSession的过程其实就是根据configuration中的配置来创建对应的类,然后返回创建的sqlSession对象)
1.5 Mybatis优缺点
-
优点
a. 简单易学
mybatis本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件易于学习,易于使用,通过文档和源代码,可以比较完全的掌握它的设计思路和实现。
b. 灵活
mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql基本上可以实现我们不使用数据访问框架可以实现的所有功能,或许更多。
c. 解除sql与程序代码的耦合
通过提供DAL层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。 -
缺点
a. 编写SQL语句时工作量很大,尤其是字段多、关联表多时,更是如此。
b. SQL语句依赖于数据库,导致数据库移植性差,不能更换数据库。
c. 框架还是比较简陋,功能尚有缺失,虽然简化了数据绑定代码,但是整个底层数据库查询实际还是要自己写的,工作量也比较大,而且不太容易适应快速数据库修改。
1.6 Mybatis与Hibernate
Hibernate是基于ORM的全自动框架,对象/关系映射能力强,不需要开发人员自己编写SQL语句(同时也不能对SQL语句进行优化);Mybatis是基于ORM半自动的,可以严格的控制SQL执行性能,灵活度高。
1.7 扩展部分
以上所述就是小编给大家介绍的《Mybatis(一)Mybatis相关概念》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 消息队列相关概念
- JNI相关概念的理解
- Zookeeper选举机制及相关概念
- 卷积神经网络(CNN)的相关概念
- Docker 入门概述(适合初学者了解相关概念)
- Python 函数式编程、装饰器以及一些相关概念简介
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
jQuery基础教程(第3版)
[美] Jonathan Chaffer、[美] Karl Swedberg / 李松峰 / 人民邮电出版社 / 2012-4 / 59.00元
内容简介: jQuery是功能强大却又简洁明快的轻量级JavaScript库,出自名家之手。在DOM操作、事件处理、Ajax特性以及动画特效等方面的出色表现,使它迅速从众多JavaScript库中脱颖而出,成为一颗闪亮的明星。 本书是《jQuery基础教程(第2版)》的升级版,涵盖了jQuery 1.6及1.7的各种新特性,内容源自著名jQuery资源网站LearningjQuery.......一起来看看 《jQuery基础教程(第3版)》 这本书的介绍吧!
正则表达式在线测试
正则表达式在线测试
RGB HSV 转换
RGB HSV 互转工具