2019独角兽企业重金招聘Python工程师标准>>>

JDBC、JDBCTemplate、MyBatis、Hiberante、Jpa关系概述

JDBC的使用

使用JDBC访问数据库的步骤:
1.得到数据库驱动程序

2.创建数据库连接

3.执行SQL语句

4.得到结果集

5.对结果集做相应的处理(增,删,改,查)

6.关闭资源:这里释放的是DB中的资源

Connection con= null;
PreparedStatement pStmt=null;
ResultSet rs = null;
try{
con = ods.getConnection();
String sql = "select * from admin";
pStmt=con.prepareStatement(sql);
rs=pStmt.executeQuery();
while(rs.next())
{ }
}
catch(Exception ex) {
try{
con.rollback();
}catch(SQLException sqlex){
sqlex.printStackTrace(System.out);
}
ex.printStackTrace();
}finally{
try{
rs.close();
pStmt.close();
con.close();
}catch(Exception e){
e.printStackTrace();
}
}

JdbcTemplate的使用

常见的JDBC代码,简单的select语句也需要冗长的出错处理,并且每个函数都不断地重复同样的代码。
JdbcTemplate正是为了减少上述繁琐的代码而设计出来的。它是对JDBC的一种封装,抽象我们常用的一些方法。Simple and Stupid就是它的目标。下面是完成了刚才JDBC代码同样功能的JdbcTemplate的代码:

String sql = "select * from admin";
jdbcTemplate.query(sql,new RowCallbackHandler() {
public void processRow(ResultSet rs) throws SQLException {
}
} );

使用模板方式封装 jdbc数据库操作-固定流程的动作,提供丰富callback回调接口功能,方便用户自定义加工细节,更好模块化jdbc操作,简化传统的JDBC操作的复杂和繁琐过程。

1) 使用JdbcTemplate 更新(insert /update /delete)

int k = jdbcTemplate.update("UPDATE tblname SET prop1=?,prop2=?...", new Object[]{...});
jdbcTemplate.update("INSERT INTO tblname VALUES(?,?,..)", new Object[]{...},new int[]{Types.VARCHAR,Types.NUMERIC});
jdbcTemplate.update("INSERT INTO tblname VALUES(?,?,..)",                     new PreparedStatementSetter(){                          public void setValues(PreparedStatement ps) throws SQLException{      ps.setLong(1, user.getId(1));ps.setString(2, user.getName(2));   ps.setDate(3, new java.sql.Date(new Date().getTime());  ps.setTimestamp(4, new Timestamp(new Date().getTime());}                     }
);

2) 使用JdbcTemplate 查询 (select)

final User user = new User();
jdbcTemplate.query("SELECT id,name,.. FROM tblname WHERE id=1",new RowCallbackHandler(){public void processRow(ResultSet rs) throws SQLException{user.setId(rs.getLong(1));user.setName(rs.getString(2));}}
);  
List uGroup = jdbcTemplate.query("SELECT id,name,.. FROM tblname WHERE igroup=1",new RowMapper(){public Object mapRow(ResultSet rs,int no) throws SQLException{User user = new User();user.setId(rs.getLong(1));user.setName(rs.getString(2));return user ;}}
}; 

3)使用JdbcTemplate 便捷方法

List uNames = jdbcTemplate.queryForList("SELECT name FROM tblname WHERE id>?",new Integer []{5}, String.class); 
List<Map> uMapList = (List<Map>) jdbcTemplate.queryForList( "SELECT id, name FROM tblname WHERE id>?",new Integer []{5});
for(Map<String,Object> uMap :uMapList){Integer id = uMap.get("id");String name = uMap.get("name");
}; 
String user = jdbcTemplate.queryForObject("SELECT name FROM tblname WHERE id=?",new Integer []{5}, String.class );
int uNum = jdbcTemplate.queryForInt("SELECT count(*) FROM tblname WHERE id>?",new Integer []{5}); 

4)使用jdbc 操作类

  • a)扩展 MappingSqlQuery类
class JdbcQueryObject extends MappingSqlQuery { // extends SqlQuerypublic JdbcQueryObject (DataSource ds,String sql){this.setDataSource( ds );this.setSql( sql );this.declareParameter(new Sqlparameter("propName",Types.VARCHAR);// propName 提示作用this.compile();}public Object mapRow(ResultSet rs,int p) throws SQLException{// ...}
}
JdbcQueryObject queryObj = new JdbcQueryObject( ds,"SELECT .. FROM tblName WHERE param=?");
List list = queryObj.execute(new Object[]{...});
  • b)使用 SqlFunction 类 查询单条结果
SqlFunction queryFun = new SqlFunction( ds,"select count(*) from tblName where ..." ,new int[]{Types.CHAR,...} );
queryFun.compile();
queryFun.run(new Object[]{p1,p2,..});
  • c)使用 SqlUpdate 类 更新
SqlUpdate updateFunc = new SqlUpdate(ds ,"INSERT tblName ...");
updateFunc.declareParameter( new SqlParameter("prop",Types.CHAR) );
updateFunc.compile();
updateFunc.update(new String[]{s1,s1});

5)支持jdbc 事务

spring的事务管理有两种方式:编程式事务、声明式事务

这里谈一下 基于数据库单一资源的编程式事务:

spring用实现TransactionDefinition接口的类定义事务的属性:传播行为;隔离级别;超时值;只读标志

默认实现为:DefaultTransactionDefinition类

PlatformTransactionManager tm =
new DataSourceTransactionManager(jdbcTemplate.getDataSource() );
TransactionStatus status = null;
try{//null 默认事务属性配置DefaultTransactionDefinitionstatus = tm.getTransaction(null);            for(final String wd: words){            try {jdbcTemplate.update( insertWordSql,new PreparedStatementSetter(){public void setValues(PreparedStatement pstate)throws SQLException {pstate.setString(1, wd) ;pstate.setTimestamp(2,new Timestamp( new Date().getTime() ));                                }                    });                    } catch (DataAccessException e) {e.printStackTrace();//tm.rollback(status);}} // end for
} finally {tm.commit(status);
}

JPA的使用

JPA全称为Java Persistence API ,Java持久化API是Sun公司在Java EE 5规范中提出的Java持久化接口。JPA吸取了目前Java持久化技术的优点,旨在规范、简化Java对象的持久化工作。使用JPA持久化对象,并不是依赖于某一个ORM框架。

在说为什么要使用JPA之前,我们有必要了解为什么要使用ORM技术。

ORM 是Object-Relation-Mapping,即对象关系影射技术,是对象持久化的核心。ORM是对JDBC的封装,从而解决了JDBC的各种存在问题:

  • a) 繁琐的代码问题

用JDBC的API编程访问数据库,代码量较大,特别是访问字段较多的表的时候,代码显得繁琐、累赘,容易出错。例如:PreparedStatement pstmt=con.prepareStatment("insert into account value(?,?,?,?,?,?,?,?,?)");

ORM则建立了Java对象与数据库对象之间的影射关系,程序员不需要编写复杂的SQL语句,直接操作Java对象即可,从而大大降低了代码量,也使程序员更加专注于业务逻辑的实现。

  • b) 数据库对象连接问题

关系数据对象之间,存在各种关系,包括1对1、1对多、多对1、多对多、级联等。在数据库对象更新的时候,采用JDBC编程,必须十分小心处理这些关系,以保证维持这些关系不会出现错误,而这个过程是一个很费时费力的过程。

ORM建立Java对象与数据库对象关系影射的同时,也自动根据数据库对象之间的关系创建Java对象的关系,并且提供了维持这些关系完整、有效的机制。

  • c) 系统架构问题

JDBC属于数据访问层,但是使用JDBC编程时,必须知道后台是用什么数据库、有哪些表、各个表有有哪些字段、各个字段的类型是什么、表与表之间什么关系、创建了什么索引等等与后台数据库相关的详细信息。

使用ORM技术,可以将数据库层完全隐蔽,呈献给程序员的只有Java的对象,程序员只需要根据业务逻辑的需要调用Java对象的Getter和 Setter方法,即可实现对后台数据库的操作,程序员不必知道后台采用什么数据库、有哪些表、有什么字段、表与表之间有什么关系。

  • d) 性能问题

采用JDBC编程,在很多时候存在效率低下的问题。

pstmt =conn.prepareStatement("insert into user_info values(?,?)");for (int i=0; i<1000; i++) {pstmt.setInt(1,i);pstmt.setString(2,"User"+i.toString());pstmt.executeUpdate();}

以上程序将向后台数据库发送1000次SQL语句执行请求,运行效率较低。

采用ORM技术,ORM框架将根据具体数据库操作需要,会自动延迟向后台数据库发送SQL请求,ORM也可以根据实际情况,将数据库访问操作合成,尽量减少不必要的数据库操作请求。

Hibernate与Jpa的关系

Jpa是一种规范,而Hibernate是它的一种实现。除了Hibernate,还有EclipseLink(曾经的toplink),OpenJPA等可供选择,所以使用Jpa的一个好处是,可以更换实现而不必改动太多代码。

pstmt =conn.prepareStatement("insert into user_info values(?,?)");for (int i=0; i<1000; i++) {pstmt.setInt(1,i);pstmt.setString(2,"User"+i.toString());pstmt.executeUpdate();}

在play中定义Model时,使用的是jpa的annotations,比如javax.persistence.Entity, Table, Column, OneToMany等等。但它们提供的功能基础,有时候想定义的更细一些,难免会用到Hibernate本身的annotation。我当时想,jpa这么弱还要用它干什么,为什么不直接使用hibernate的?反正我又不会换成别的实现。

因为我很快决定不再使用hibernate,这个问题就一直放下了。直到我现在在新公司,做项目要用到Hibernate。

我想抛开jpa,直接使用hibernate的注解来定义Model,很快发现了几个问题:

  1. jpa中有Entity, Table,hibernate中也有,但是内容不同
  2. jpa中有Column,OneToMany等,Hibernate中没有,也没有替代品

我原以为hibernate对jpa的支持,是另提供了一套专用于jpa的注解,但现在看起来似乎不是。一些重要的注解如Column, OneToMany等,hibernate没有提供,这说明jpa的注解已经是hibernate的核心,hibernate只提供了一些补充,而不是两套注解。要是这样,hibernate对jpa的支持还真够足量,我们要使用hibernate注解就必定要使用jpa。

“如果hibernate认为jpa的注解够用,就直接用。否则会弄一个自己的出来作为补充”

jpa和hibernate都提供了Entity,我们应该用哪个,还是说可以两个一起用?网友回答说“Hibernate的Entity是继承了jpa的,所以如果觉得jpa的不够用,直接使用hibernate的即可”。

参考:https://my.oschina.net/pingpangkuangmo/blog/404280

转载于:https://my.oschina.net/momomo1987/blog/1492581

JDBC,JdbcTemplate,JPA傻傻分不清楚相关推荐

  1. JDBC,JdbcTemplate,JPA,Hibernate之间的关系概述

    什么是JDBC? Java语言访问数据库的一种规范,是一套API.JDBC (Java Database Connectivity) API,即Java数据库编程接口,是一组标准的Java语言中的接口 ...

  2. Spark on Hive Hive on Spark傻傻分不清?

    Spark on Hive? Hive on Spark傻傻分不清? 1 spark on hive Spark on hive,是spark计算引擎依托hive data source,spark ...

  3. Java:接口和抽象类,傻傻分不清楚?

    再来聊聊接口和抽象类. 01.抽象类和接口的区别 来看网络上对接口的一番解释: 接口(英文:Interface),在 Java 编程语言中是一个抽象类型,是抽象方法的集合.一个类通过继承接口的方式,从 ...

  4. JS魔法堂:属性、特性,傻傻分不清楚

    一.前言 或许你和我一样都曾经被下面的代码所困扰 var el = document.getElementById('dummy'); el.hello = "test"; con ...

  5. ASP.NET MVC涉及到的5个同步与异步,你是否傻傻分不清楚?[下篇]

    关于ASP.NET MVC对请求的处理方式(同步或者异步)涉及到的五个组件,在<上篇>中我们谈了三个(MvcHandler.Controller和ActionInvoker),现在我们来谈 ...

  6. 科普 | Shell中傻傻分不清楚的TOP3

    近来小姐姐又犯憨憨错误,问组内小伙伴export命令不会持久化环境变量吗?反正我是问出口了..然后小伙伴就甩给了我一个<The Linux Command Line>PDF链接.感谢老大不 ...

  7. 国家电网和南方电网还傻傻分不清?

    参看:都2020年了,国家电网和南方电网还傻傻分不清? 一.名称不同 一个叫南方电网,一个叫国家电力电网,虽然都是电网,但是区别还是很大的 而且成立时间不一样:国家电力电网有限公司成立于2002年12 ...

  8. cdn厂商 同兴万点_同兴万点:TXNetworks和CDNetworks让我们傻傻分不清

    原标题:同兴万点:TXNetworks和CDNetworks让我们傻傻分不清 在2008年2月25日成立的同兴万点,公司全称为同兴万点(北京)网络技术有限公司(TXNetworks),一直专注于CDN ...

  9. 2021年了,`IEnumerator`、`IEnumerable`接口还傻傻分不清楚?

    IEnumerator.IEnumerable这两个接口单词相近.含义相关,傻傻分不清楚. 入行多年,一直没有系统性梳理这对李逵李鬼. 最近本人在怼着why神的<其实吧,LRU也就那么回事> ...

最新文章

  1. 中科院遗传发育所白洋组项目聘用工作人员招聘启事
  2. Beta 冲刺(5/7)
  3. DOCTYPE声明作用及用法详解
  4. python 语言教程(2)基础语法之标识符
  5. 近世代数--内直积--内直积是什么?充要条件?
  6. autotype安全 fastjson_Fastjson 安全更新,建议升级到 1.2.28 或更新版本
  7. docker安装部署_有关docker安装yearning和部署inception(闭源)
  8. vue.js视频课程_在此免费课程中学习Vue.js! ✨
  9. 宝马无法gps定位_2.0T+后驱,豪华品牌论运动还得看它,带你看宝马3系
  10. 李沐老师的PyTorch 版《动手学深度学习》PDF 开源了(全中文,支持 Jupyter 运行)
  11. 华为的薪酬福利与激励体系
  12. 【SpringBoot整合缓存】-----jetcache以及j2cache篇
  13. Android 官方现代 App 架构指南
  14. 入门者必备——fpga芯片速度等级认识
  15. linux cli运行脚本,AWS学习笔记(四)--CLI创建EC2时执行脚本
  16. dex2oat对应用启动性能的影响
  17. git基本命令与git基本命令-远程
  18. 【AI每日播报】首次超越LSTM : Facebook 门卷积网络新模型能否取代递归模型
  19. ubuntu的视频录制功能
  20. Linux 命令(198)—— host 命令

热门文章

  1. 如何运行ImageMagick的命令行工具
  2. html 显示消息数量,html实现消息按钮上的数量角标的实例详解
  3. python合并k个有序链表_Leetcode合并K个升序链表(Python版本),LeetCode,python
  4. java线程的优先级是数字越大优先级越高_《深入理解Java虚拟机》5分钟速成:12章(Java内存模型与线程)...
  5. wowpve服务器优势,PVE服务器法师对本职业的一点看法
  6. python基础主要内容_python基础—python的介绍
  7. unity3d 切换网络_Unity3d新网络请求方式UnityWebRequest详解
  8. 3 OC 属性和方法
  9. 实现简书个人中心UI效果
  10. Spring Boot @ConfigurationProperties使用指导