JDBC vs Hibernate(转)】的更多相关文章

首先来看一下原生JDBC访问数据库的代码: public static void main(String[] args) { // 数据库连接 Connection connection = null; // 预编译的Statement,使用预编译的Statement提高数据库的性能 PreparedStatement statement = null; // 结果集 ResultSet resultSet = null; try { // 加载数据库驱动 Class.forName("com.…
以查询一个用户信息(id,name)为例: JDBC 1. 获取一个connection 2. 生成一个statement 3. 拼接SQL语句 4. 查询对象,获取结果集(假设已经找到我们需要的对象) 5. 读取结果集信息,封装成需要的用户对象 6. 关闭结果集,statement,connection Hibernate 1. 建立用户信息对象,并配置好对象关系映射 2. 获取一个Session对象 3. 生产一个Query对象 4. 编写HQL语句 5. 执行Query.list()方法,…
一.传统的JDBC编程 在java开发中,以前都是通过JDBC(Java Data Base Connectivity)与数据库打交道的,至少在ORM(Object Relational Mapping)框架没出现之前是这样,目前常用的ORM框架有JPA.hibernate.mybatis.spring jdbc等,我一开始也是使用JDBC编程,后面开始使用hibernate,有一次开发一个CRM管理系统使用的是Spring JDBC操作数据库,但个人还是不太喜欢这个框架,本人目前使用的最多还是…
先比较下jdbc编程和hibernate编程各自的优缺点.    JDBC:    我们平时使用jdbc进行编程,大致需要下面几个步骤:    1,使用jdbc编程需要连接数据库,注册驱动和数据库信息    2,操作Connection,打开Statement对象    3,通过Statement对象执行SQL,返回结果到ResultSet对象    4,使用ResultSet读取数据,然后通过代码转化为具体的POJO对象    5,关闭数据库相关的资源   jdbc的缺点:   一:工作量比较…
相同点:都是数据库操作的中间件,都不是线程安全需要即时关闭,都可以对数据库操作进行显式处理. 不同:jdbc使用标准sql语言,hibernate使用HQL,操作对象jdbc直接操作数据传送到数据库,hibernate操作的是对象,然后更新到数据库:jdbc是瞬时的,变量数值不与数据库实时同,hibernate操作持久,数据和数据库中保持一致. JDBC Scrollable Result (消耗时间最少) < Hibernate List < JDBC Result < Hiberna…
首先来看一下原生JDBC访问数据库的代码: public static void main(String[] args) { // 数据库连接 Connection connection = null; // 预编译的Statement,使用预编译的Statement提高数据库的性能 PreparedStatement statement = null; // 结果集 ResultSet resultSet = null; try { // 加载数据库驱动 Class.forName("com.…
相同点: ◆两者都是JAVA的数据库操作中间件. ◆两者对于数据库进行直接操作的对象都不是线程安全的,都需要及时关闭. ◆两者都可以对数据库的更新操作进行显式的事务处理. 不同点: ◆使用的SQL语言不同:JDBC使用的是基于关系型数据库的标准SQL语言,Hibernate使用的是HQL(Hibernate query language)语言 ◆操作的对象不同:JDBC操作的是数据,将数据通过SQL语句直接传送到数据库中执行,Hibernate操作的是持久化对象,由底层持久化对象的数据更新到数据…
详解JDBC与Hibernate区别 引用地址:http://www.cnblogs.com/JemBai/archive/2011/04/13/2014940.html 刚开始学习JAVA时,认为Hibernate是一个很神圣的东西,好像是会了SSH,就能走遍全世界一样.记得曾经在枫叶面试的时候,我们几个同 学出还说这个公司怎么这么的落后,还有JDBC,没有一点上进心.可是毕业以后才发现,却发现自已就像是井底之蛙一样.然而也不想做随风柳絮,所以决定好 好的总结一下,JDBC与Hibernate…
jdbc和Hibernate区别 刚开始学习JAVA时,认为Hibernate是一个很神圣的东西,好像是会了SSH,就能走遍全世界一样.记得曾经在枫叶面试的时候,我们几个同学出还说这个公司怎么这么的落后,还有JDBC,没有一点上进心.可是毕业以后才发现,却发现自已就像是井底之蛙一样.然而也不想做随风柳絮,所以决定好好的总结一下,JDBC与Hibernate的区别. JDBC与Hibernate在性能上相比,JDBC灵活性有优势.而Hibernate在易学性,易用性上有些优势.当用到很多复杂的多表…
Hibernate是一个轻量级的持久层开源框架,它是连接Java应用程序和关系数据库的中间件,负责Java对象和关系数据之间的映射.Hibernate内部对JDBC API进行了封装,负责Java对象的持久化.因为它封装了所有的数据访问细节,使得业务逻辑层可以专注于实现业务逻辑. 它是一种优秀的ORM映射工具,提供了完善的对象-关系映射服务,开发过程不依赖容器,灵活性非常大,可以无缝集成到任何一个java系统中. JDBC和Hibernate都是用于数据持久化操作的. JDBC: 1.实现业务逻…
JDBC中:设置从1开始 例: Connection con = DriverManager.getConnection("jdbc:mysql://localhost/...","root","123"); String sql = "insert into t_user values (?,?,?)"; PreparedStatment ps = con.prepared(sql); ps.setString(1,&quo…
一.JDBC.Connection(连接) 优点:运行高效.快捷. 缺点:代码多.异常多.不支持跨平台. 二.ibatis 1.根据jdbc的基本建立连接. 2.通过anntation+xml.java反射技术,实现与关系数据库的转化. 3.优点:高效.复杂的sql构建,支持与spring的整合,与AOP事物.结果集做了轻量级的封装,支持缓存.  缺点:需要自己编写SQL语句 三.hibernate 1.对JDBC进行了轻量级的封装,针对于持久化层. 问:如何对hibernate进行优化 答:优…
在学习使用mybatis之前,先比较下jdbc编程和hibernate编程各自的优缺点. JDBC: 我们平时使用jdbc进行编程,大致需要下面几个步骤: 1,使用jdbc编程需要连接数据库,注册驱动和数据库信息 2,操作Connection,打开Statement对象 3,通过Statement对象执行SQL,返回结果到ResultSet对象 4,使用ResultSet读取数据,然后通过代码转化为具体的POJO对象 5,关闭数据库相关的资源 jdbc的缺点: 一:工作量比较大,需要连接,然后处…
比较三种查询方式查询效率对比...我是用的JavaWeb的方式通过通过JSP页面查询的填写查询的参数...给予反馈.... 整个demo的下载地址:http://files.cnblogs.com/files/DreamDrive/redis2sql.rar 1.后台对应的表结构: 创建表的SQL语句: CREATE TABLE `asset` ( `assetid` ) NOT NULL AUTO_INCREMENT, `assetname` ) DEFAULT NULL, `region`…
1.100 用户同时来访数据库,要采取什么技术? 答:采用数据库连接池. 2.什么是ORM? 答:对象关系映射(Object—Relational Mapping,简称ORM)是一种为了解决面向对象与面向关系数据库存在的互不匹配的现象的技术:简单的说,ORM 是通过使用描述对象和数据库之间映射的元数据,将java 程序中的对象自动持久化到关系数据库中:本质上就是将数据从一种形式转换到另外一种形式. 3.Hibernate 有哪5 个核心接口? 答:Configuration 接口:配置Hiber…
从层次上看,JDBC是较底层的持久层操作方式,而Hibernate和MyBatis都是在JDBC的基础上进行了封装使其更加方便程序员对持久层的操作. 从功能上看, JDBC就是简单的建立数据库连接,然后创建statement,将sql语句传给statement去执行,如果是有返回结果的查询语句,会将查询结果放到ResultSet对象中,通过对ResultSet对象的遍历操作来获取数据: Hibernate是将数据库中的数据表映射为持久层的java对象,实现数据表的完整性控制: MyBatis是将…
JDBC     Hibernate Mybatis    (Java  DataBase Connnection) 是通过JAVA访问数据库 对JDBC的轻量封装 像操作对象操作数据库 对SQL的轻量封装 是ORM框架 前身(ibatis) 导入mysql包 项目结构 项目结构 CRUD CRUD CRUD 查询 executeQuery 执行SQL查询语句 查询 查询 特殊操作 (获取自增长id) 通过Statement的getGeneratedKeys 获取该id (获取表的元数据) 查询…
Hibernate映射类型 java类型 标准SQL类型 integer java.lang.Integer integer long java.lang.Long bigint short java.lang.Short smallint float java.lang.Float float double java.lang.Float double big_decimal java.math.BigDecimal numeric character java.lang.String cha…
如果不用spring管理事务,我们自己写代码来操作事务.那么这个代码怎么写要看底层怎么访问数据库了. 当采用原生JDBC访问数据库时,操作事务需要使用java.sql.Connection的API.开启事务用Connection对象的setAutoCommit(boolean autoCommit)方法,执行完与数据库相关的业务操作后,再调用commit()实例方法来提交事务: // 获取Connection对象 Connection con = getCon(); // 开启事务 con.se…
来自: http://blog.csdn.net/an_2016/article/details/51759890 一.批量插入(两种方式) 1,通过hibernate缓存 如果这样写代码进行批量插入(初始设想): package com.anlw.util; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transaction; import org.hiberna…
本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 -----------------------------------------------------------------------------------------------------------------…
在Hibernate中使用JDBC事务 Hibernate对JDBC进行了轻量级的封装,它本身在设计时并不具备事务处理功能.Hibernate将底层的JDBCTransaction或JTATransaction进行了封装,再在外面套上Transaction和Session的外壳,其实是通过委托底层的JDBC或JTA来实现事务的处理功能的. 要在Hibernate中使用事务,可以在它的配置文件中指定使用JDBCTransaction或者JTATransaction.在hibernate.prope…
1.hibernate是一个开源的.采用面向对象的思想实现ORM映射框架,它对jdbc进行了一层封装,对于数据库的连接.关闭.数据的持久化(增删改查).事务的管理都进行了封装,使得程序开发的时候可以用面向对象的思想来操作数据库. 2.hibernate可以用于jdbc应用的任何场合.优点是,使用面向对象的思想操作数据库:对jdbc的封装,使得开发中不需要写大量的sql语句,大大提高了开发效率:采用数据库方言等方式使得数据库移植十分方便,也使得在开发中不需要考虑数据之间的差异:提供缓存机制,提高查…
文章出处:Jdbc,Mybatis,Hibernate各自优缺点及区别 先比较下jdbc编程和hibernate编程各自的优缺点. 1.JDBC 我们平时使用jdbc进行编程,大致需要下面几个步骤:   1.使用jdbc编程需要连接数据库,注册驱动和数据库信息:   2.操作Connection,打开Statement对象:   3.通过Statement对象执行SQL,返回结果到ResultSet对象:   4.使用ResultSet读取数据,然后通过代码转化为具体的POJO对象:   5.关…
当数据库有大量用户来访问要采取什么技术解决 可以采用连接池: 什么是ORM 对象关系映射(Object Relational Mapping 简称ORM)是一种为了解决面向对象与面向关系数据库存在的互不匹配的想象的技术:简单的说,ORM是通过使用描述对象和数据库之间映射的元数据,将Java程序中的对象自动持久化到关系数据库中:本质上就是将数据从一种形式转换到另一种形式. Hibernate有哪5个核心接口. Configuration接口:配置Hibernate,根据其启动Hibernate,创…
二.OOA/D 与UML 部分:(共6 题:基础2 道,中等难度4 道) 96.UML 是什么?常用的几种图?[基础] 答:UML 是标准建模语言:常用图包括:用例图,静态图(包括类图.对象图和包图),行为图,交互图(顺序图,合作图),实现图. 97.编程题: 写一个Singleton 出来.[基础] 答:Singleton 模式主要作用是保证在Java 应用程序中,一个类Class 只有一个实例存在.举例:定义一个类,它的构造函数为private 的,它有一个static的private 的该…
JDBC: 我们平时使用jdbc进行编程,大致需要下面几个步骤: 1,使用jdbc编程需要连接数据库,注册驱动和数据库信息 2,操作Connection,打开Statement对象 3,通过Statement对象执行SQL,返回结果到ResultSet对象 4,使用ResultSet读取数据,然后通过代码转化为具体的POJO对象 5,关闭数据库相关的资源 jdbc的缺点: 一:工作量比较大,需要连接,然后处理jdbc底层事务,处理数据类型,还需要操作Connection,Statement对象和…
Hibernate需要进行数据库访问,因此必须设置连接数据库的相关属性.所有Hibernate属性的名字和语义都在org.hibernate.cfg.Environment中定义. 关于JDBC连接配置中最重要的设置: ⊙ hiberante.connection.driver_class : 设置连接数据库的驱动. ⊙ hibernate.connection.url : 设置所需连接数据库服务的URL. ⊙ hibernate.connection.username : 设置连接数据库的用户…
文章大纲 一.jdbc介绍二.Mybatis介绍三.Hibernate介绍四.jdbc.Mybatis.Hibernate比较五.参考文章   一.jdbc介绍 1. jdbc编程步骤 (1)加载数据库驱动(2)创建并获取数据库链接(3)创建jdbc statement对象(4)设置sql语句(5)设置sql语句中的参数(使用preparedStatement)(6)通过statement执行sql并获取结果(7)对sql执行结果进行解析处理(8)释放资源(resultSet.prepareds…
在hibernate中获取connection数据库连接有两种方法:(操作数据库常用这种方法) 1. session.doReturningWork   返回一个对象,适用于查询方法 2. session.doWork      不返回对象,适用于增删改 案例一: package action; import java.sql.Connection; import java.sql.SQLException; import org.apache.commons.dbutils.QueryRunn…