JDBC、MyBatis、Hibernate的区别

JDBC

1.使用JDBC编程需要链接数据库,注册驱动和数据库信息。

2.操作Connection,打开Statement对象。

3.通过Statement执行SQL语句,返回结果放到ResultSet对象。

4.使用ResultSet读取数据。

5.关闭数据库相关的资源。

JDBC缺点:

工作量比较大,需要连接,然后处理jdbc底层事务,处理数据类型,还需要操作Connection,Statement对象和ResultSet对象去拿数据并关闭他们

没有使用框架的时候 sql语句是和java语句一起写在dao层 耦合度高,维护不易而且实际开发中sql是会变的,需要频繁修改 当你要替换某个sql代码的时候

,需要对整个项目 进行操作,极不方便。

JDBC优点:

接近底层,理论上效率最高

MyBatis

半自动化的持久层框架 半自动 轻量级 

1.SQLSessionFactoryBuilder(构造器):它会根据配置信息或者代码生成SqlSessionFactory。

2.SqlSessionFactory(工厂接口):依靠工厂生成SqlSession。

3.SqlSession(会话):是一个既可以发送SQL去执行并且返回结果,也可以获取Mapper接口。

4.SQL Mapper:是由一个JAVA接口和XML文件(或注解)构成,需要给出对应的SQL和映射规则。SQL是由Mapper发送出去,并且返回结果。

Mybatis的优点:

1、易于上手和掌握,提供了数据库查询的自动对象绑定功能,而且延续了很好的SQL使用经验,对于没有那么高的对象模型要求的项目来说,相当完美。

2sql写在xml里,便于统一管理和优化, 解除sql与程序代码的耦合。

3、提供映射标签,支持对象与数据库的orm字段关系映射

4提供对象关系映射标签,支持对象关系组建维护

5、提供xml标签,支持编写动态sql

6、速度相对于Hibernate的速度较快

Mybatis的缺点:

1、关联表多时,字段多的时候,sql工作量很大。

2sql依赖于数据库,导致数据库移植性差。

3、由于xml里标签id必须唯一,导致DAO中方法不支持方法重载。

4、对象关系映射标签和字段映射标签仅仅是对映射关系的描述,具体实现仍然依赖于sql

5DAO层过于简单,对象组装的工作量较大。

6、不支持级联更新、级联删除。

7Mybatis的日志除了基本记录功能外,其它功能薄弱很多。

8、编写动态sql,不方便调试,尤其逻辑复杂时。

9、提供的写动态sqlxml标签功能简单,编写动态sql仍然受限,且可读性低。

Hibernate

Hibernate的优点:

1hibernate是全自动,hibernate完全可以通过对象关系模型实现对数据库的操作,拥有完整的JavaBean对象与数据库的映射结构来自动生成sql

2、功能强大,数据库无关性好,O/R映射能力强,需要写的代码很少,开发速度很快。

3、有更好的二级缓存机制,可以使用第三方缓存。

4、数据库移植性良好。

5hibernate拥有完整的日志系统,hibernate日志系统非常健全,涉及广泛,包括sql记录、关系异常、优化警告、缓存提示、脏数据警告等

Hibernate的缺点:

1、学习门槛高,精通门槛更高,程序员如何设计O/R映射,在性能和对象模型之间如何取得平衡,以及怎样用好Hibernate方面需要的经验和能力都很强才行

2hibernatesql很多都是自动生成的,无法直接维护sql;虽然有hql查询,但功能还是不及sql强大,见到报表等变态需求时,hql查询要虚,也就是说hql查询是有局限的;hibernate虽然也支持原生sql查询,但开发模式上却与orm不同,需要转换思维,因此使用上有些不方便。总之写sql的灵活度上hibernate不及mybatis

posted @ 2019-04-03 19:57  三只小菜鸟  阅读(1589)  评论(0编辑  收藏  举报