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使用经验,对于没有那么高的对象模型要求的项目来讲,至关完美。
2、sql写在xml里,便于统一管理和优化, 解除sql与程序代码的耦合。
3、提供映射标签,支持对象与数据库的orm字段关系映射
4、 提供对象关系映射标签,支持对象关系组建维护
5、提供xml标签,支持编写动态sql。
6、速度相对于Hibernate的速度较快
Mybatis的缺点:
1、关联表多时,字段多的时候,sql工做量很大。
2、sql依赖于数据库,致使数据库移植性差。
3、因为xml里标签id必须惟一,致使DAO中方法不支持方法重载。
4、对象关系映射标签和字段映射标签仅仅是对映射关系的描述,具体实现仍然依赖于sql。
5、DAO层过于简单,对象组装的工做量较大。
6、不支持级联更新、级联删除。
7、Mybatis的日志除了基本记录功能外,其它功能薄弱不少。
8、编写动态sql时,不方便调试,尤为逻辑复杂时。
9、提供的写动态sql的xml标签功能简单,编写动态sql仍然受限,且可读性低。
Hibernate
Hibernate的优势:
1、hibernate是全自动,hibernate彻底能够经过对象关系模型实现对数据库的操做,拥有完整的JavaBean对象与数据库的映射结构来自动生成sql。
2、功能强大,数据库无关性好,O/R映射能力强,须要写的代码不多,开发速度很快。
3、有更好的二级缓存机制,可使用第三方缓存。
4、数据库移植性良好。
5、hibernate拥有完整的日志系统,hibernate日志系统很是健全,涉及普遍,包括sql记录、关系异常、优化警告、缓存提示、脏数据警告等
Hibernate的缺点:
1、学习门槛高,精通门槛更高,程序员如何设计O/R映射,在性能和对象模型之间如何取得平衡,以及怎样用好Hibernate方面须要的经验和能力都很强才行
2、hibernate的sql不少都是自动生成的,没法直接维护sql;虽然有hql查询,但功能仍是不及sql强大,见到报表等变态需求时,hql查询要虚,也就是说hql查询是有局限的;hibernate虽然也支持原生sql查询,但开发模式上却与orm不一样,须要转换思惟,所以使用上有些不方便。总之写sql的灵活度上hibernate不及mybatis。