JDBC、MyBatis、Hibernate的区别?

JDBC

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

2.操做Connection,打开Statement对象。程序员

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

4.使用ResultSet读取数据。数据库

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

JDBC缺点:缓存

工做量比较大,须要链接,而后处理jdbc底层事务,处理数据类型,还须要操做Connection,Statement对象和ResultSet对象去拿数据并关闭他们mybatis

没有使用框架的时候 sql语句是和java语句一块儿写在dao层 耦合度高,维护不易并且实际开发中sql是会变的,须要频繁修改 当你要替换某个sql代码的时候,须要对整个项目 进行操做,极不方便。app

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

相关文章
相关标签/搜索