虽然在平时的开发过程中我们不会直接使JDBC的API来操作数据库,但是JDBC是大多数ORM框架的基础。只有掌握了JDBC的使用才能更好的掌握ORM框架。本篇博客就对JDBC做下介绍,以及使用JDBC操作数据库的一般流程。


JDBC(Java数据库连接)是Sun公司提供的一组操作数据库的接口。各个数据库厂商提供具体的数据库驱动实现类。开发者就可以通过统一的JDBC API来访问各类数据库了。JDBC可以帮我们完成下面三件事:

  • 建立数据库连接;
  • 执行各类SQL语句;
  • 获得SQL语句执行的结果。

1. 常用类

  • DriverManager:主要使用该类获取数据库连接对象;
public static Connection getConnection(String url,
String user, String password) throws SQLException
  • Connection:代表数据库连接对象,每个对象代表一个数据库物理连接,在操作数据库之前必须先获得该对象;该接口常用的方法如下:
//返回一个Statement对象
Statement createStatement() throws SQLException;
//返回一个预编译的Statement对象,也就是先将Sql语句提交到数据库进行预编译
PreparedStatement prepareStatement(String sql) throws SQLException;
//该对象用于调用存储过程
CallableStatement prepareCall(String sql) throws SQLException;

另外Connection对象还提供了如下对象来对事务进行操作:

//设置回滚点
Savepoint setSavepoint() throws SQLException;
Savepoint setSavepoint(String name) throws SQLException;
//设置隔离级别
void setTransactionIsolation(int level) throws SQLException;
//设置回滚点
void rollback() throws SQLException;
void rollback(Savepoint savepoint) throws SQLException;
void setAutoCommit(boolean autoCommit) throws SQLException;
//提交事务
void commit();
  • Statement:用于执行SQL语句的工具接口,可以执行DDL、DML和查询语句,常用方法如下:
//执行查询SQL,并返回结果集
ResultSet executeQuery(String sql) throws SQLException;
//执行DML,并返回影响的条数,也可以执行DDL,返回0
int executeUpdate(String sql) throws SQLException;
//可以执行所有SQL,如果SQL是查询语句并能查到结果返回true,否则返回false
boolean execute(String sql) throws SQLException;
  • PreparedStatement:预编译的Statement,不需要每次去数据库编译SQL语句,只要给SQL执行参数就可以了 。
  • ResultSet:结果集。

2. JDBC编程步骤

/**
* step1:加载驱动;
* step2:获得连接;
* step3:创建Statement;
* step4:执行语句,获取结果集;
* step5:处理结果集;
* step6:关闭资源(ResultSet、Statement和Connection)
*/

3. 事务处理

//开启事务
setAutoCommit(fasle);
//遇到异常回滚
//提交事务
commit();

4. 数据库连接池

每次创建数据库的连接是比较耗费资源的,所以将数据库连接资源缓存起来,重复利用。

  • DBCP
  • C2P0
  • Durid

5. JDBC列子代码

下面是一个最简单的JDBC列子代码,是一个最典型的JDBC查询过程。


public class JDBCUtil { public static final Logger log = LoggerFactory.getLogger(JDBCUtil.class); public static final String URL = "jdbc:mysql://127.0.0.1/mysql";
public static final String DRIVER = "com.mysql.jdbc.Driver";
public static final String USERNAME = "root";
public static final String PASSWORD = "root"; private Connection getConnection(){
Connection conn = null;
try {
Class.forName(DRIVER);
conn = DriverManager.getConnection(URL,USERNAME,PASSWORD);
} catch (ClassNotFoundException e) {
log.error("get connection exception",e);
}catch (SQLException e) {
log.error("get connection exception",e);
}
return conn;
} public void queryAndEchoUser(String userName){
String sql = "select * from user where user = ?";
Connection connection = getConnection();
PreparedStatement preparedStatement;
ResultSet resultSet=null;
try {
preparedStatement = connection.prepareStatement(sql);
preparedStatement.setString(1,"root");
resultSet = preparedStatement.executeQuery();
while (resultSet.next()){
log.info("host-->"+resultSet.getString(1));
}
} catch (SQLException e) {
//
}finally {
//close resultSet
//close preparedStatement
//close connection
}
} }

6. 使用Apache的JDBC工具类

上面的代码略微显得复杂,特别是将查出来的结果集转换为Bean对象,关闭资源那块。使用Apache提供的工具类能适当减少这样的模板代码:

public class DbUtilsUseBeanMySQL {
public static void main(String[] args) {
Connection conn = null;
String jdbcURL = "jdbc:mysql://localhost/octopus";
String jdbcDriver = "com.mysql.jdbc.Driver";
String user = "root";
String password = "root"; try {
DbUtils.loadDriver(jdbcDriver);
conn = DriverManager.getConnection(jdbcURL, user, password); QueryRunner qRunner = new QueryRunner();
List beans = (List) qRunner.query(conn, "select id, name from animals_table",
new BeanListHandler(Employee.class)); for (int i = 0; i < beans.size(); i++) {
Employee bean = (Employee) beans.get(i);
bean.print();
}
} catch (SQLException e) {
// handle the exception
e.printStackTrace();
} finally {
DbUtils.closeQuietly(conn);
}
}
}

当然以上只是DbUtil最简单的使用,这个工具还支持数据源,事务管理等高级特性,需要的时候可以查询API使用。

公众号推荐

欢迎大家关注我的微信公众号「程序员自由之路」

【Java基础】JDBC简明教程的更多相关文章

  1. Java网络编程简明教程

    Java网络编程简明教程 网络编程  计算机网络相关概念 计算机网络是两台或更多的计算机组成的网络,同一网络内的任意两台计算机可以直接通信,所有计算机必须遵循同一种网络协议. 互联网 互联网是连接计算 ...

  2. ava基础MySQL存储过程 Java基础 JDBC连接MySQL数据库

    1.MySQL存储过程   1.1.什么是存储过程 带有逻辑的sql语句:带有流程控制语句(if  while)等等 的sql语句   1.2.存储过程的特点 1)执行效率非常快,存储过程是数据库的服 ...

  3. Java基础部分全套教程.

    这是我自己早前听课时整理的java基础全套知识,使用于初学者,也可以适用于中级的程序员,我做成了chm文档的类型,你们可以下载 笔记是比较系统全面,可以抵得上市场上90%的学习资料.讨厌那些随便乱写的 ...

  4. JAVA基础-JDBC(一)

    一.JDBC的简介 JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,由与各种数据库都有着一套自己的规范,JAVA对其操 ...

  5. JAVA基础-JDBC二(常用的开源工具)

    一.连接池 在实际的开发应用中,我们常常会对数据库进行大量的高并发的访问,而最原始的连接和操作方式并不能满足这种大量的访问,程序员为了追求更方便.更快捷.更科学安全的开发.第三方的工具类和Dao层的框 ...

  6. Java基础 JDBC

    一,前言 数据库是开发中必不可少的一个工具,那么java如何操作数据库呢,那就是我们的JDBC了,接下来我们将会好好聊一下这个JDBC. 二,JDBC 2.1 JDBC概述 JDBC(Java Dat ...

  7. [转]Java NIO通俗易懂简明教程

    Java NIO(New IO)是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的Java IO API.本系列教程将有助于你学习和理解Java NIO. Java NIO提供了与 ...

  8. Java基础——JDBC

    今天学习的内容是:JDBC 通常jdbc连接分6步: 1)注册驱动: 2)建立连接: 3)创建Statement: 4)执行sql 语句: 5)处理结果集(若sql 语句为查询语句): 6)关闭连接. ...

  9. Java基础-JDBC访问数据库

    基本步骤: 加载数据库驱动 建立连接 创建SQL语句 执行SQL语句 处理执行结果 释放资源 代码示例: import java.sql.Connection; import java.sql.Dri ...

随机推荐

  1. 数组(Array)和列表(ArrayList)有什么区别?什么时候应该使用Array而不是ArrayList?

    下面列出了Array和ArrayList的不同点:Array可以包含基本类型和对象类型,ArrayList只能包含对象类型.Array大小是固定的,ArrayList的大小是动态变化的.ArrayLi ...

  2. CCF-CSP题解 201509-4 高速公路

    有点忧愁.\(CSP\)也考\(Tarjan\)缩点的嘛. 原理咱也不明白,咱也不敢学,找到模板就是抄. #include<bits/stdc++.h> const int maxn = ...

  3. Elasticsearch 监控指标解析

    1.集群监控 集群监控主要包括两个方面的内容,分别是集群健康情况和集群的运行状态. 集群健康状态可以通过以下api获取: http://ip:9200/_cluster/health?pretty 关 ...

  4. oopday02(面向对象-构造方法&静态static)

    面向对象之封装 01_面向对象(构造方法Constructor概述和格式) * A:构造方法概述和作用 * 给对象的数据(属性)进行初始化 * B:构造方法格式特点 * a:方法名与类名相同(大小也要 ...

  5. Hadoop_简介_01

    1. Apache Hadoop 1.1 Hadoop介绍 Hadoop是Apache旗下的一个用java语言实现的开源软件框架, 是一个开发和运行处理大规模数据的软件平台. 允许使用简单的编程模型在 ...

  6. [C]struct结构化数据的一些要点

    1.用typedef声明一个短语代替冗长的struct成员声明 int main(void) { typedef struct Hores Hores; struct Hores { int age; ...

  7. 周末DHU友谊赛(半日游)感想

    DHU的校园挺好的啊,感觉教学楼啊,整体环境啊比咱学校好上一些,和大家一起出来有些春(冬)游的意味,食堂也是十分的宽敞,座位好多! 吐槽shu的食堂座位到饭点明显太少,食堂品类好多,shu的吃多了感觉 ...

  8. 爬虫(三):urllib模块

    1. urllib模块 1.1 urllib简介 urllib 是 Python3 中自带的 HTTP 请求库,无需复杂的安装过程即可正常使用,十分适合爬虫入门 urllib 中包含四个模块,分别是: ...

  9. Ligg.WinOa-000: Windows运维自动化编程实战--前言

        本开源项目Ligg.WinOa是一个基于Ligg.EasyWinApp的Windows运维自动化应用.通过Ligg.EasyWinForm生成2个功能界面:管理员工具箱和用户工具箱:通过Lig ...

  10. Class文件结构-常量池

    常量池里存放:1.字面量(Literal) • 文本字符串 • 声明为final的常量值(final的8种基本类型) • 非final的基本类型也可能进(doublefloatlong)2.符号引用( ...