说明:本系列学习笔记主要是学习传智播客的李勇老师的教学课程和一本英文电子书《JDBC Recipes A Problem-Solution Approach》所作的笔记。
1,什么是JDBC?
其实JDBC是API的一个集合,它允许你使用java语言对数据库操作。它的核心是接口,也有少量的类。它主要在java.sql和javax.sql两个包。
java.sql这个包主要是提供了一些访问并操作数据库的接口,这个包提供了大量的重要的objects (比如Connection, ResultSet, Statement, and PreparedStatement).
javax.sql则提供了服务端数据处理的接口。
下面的图是java应用使用java访问数据库的。
从这张图中可以看出,java应用程序使用JDBC的API对数据库进行访问,但是其中隔了许多的东西,有必要解释一下。
java应用程序通过JDBC应用程序接口访问JDBC’s DriverManager,这个JDBC驱动管理器管理许多不同的驱动,比如Oracle的、Mysql的驱动,当程序加载了某个驱动的时候,就会通过这个驱动访问某个数据库了。这些驱动当然都是各个数据库厂家实现的,但是都必须按照JDBC的API来实现。
下面是个简单的JDBC架构:它使用JDBC来访问数据库,但是省略了其中的细节。
下面是个详细的JDBC架构,它和我们文章的第一个图类似。
2,一个简单的例子
理论再天花乱坠,大家都不喜欢,整个简单的实例:
步骤:
1. Import the required packages.
2. Register the JDBC drivers.
3. Open a connection to a database.
4. Create a Statement object.
5. Execute a query and return a ResultSet object.
6. Process the ResultSet object.
7. Close the ResultSet and Statement objects.
8. Close the connection.
1,找到相关的驱动包,我这里新建一个简单的java工程,下载驱动包。我这里是连接Oracle数据库,所以就下载Oracle驱动。
2,注册JDBC驱动,这个你把包加入进来JVM是不识别的,你必须告诉它。
Class.forName("oracle.jdbc.driver.OracleDriver");
3,建立一个连接。
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl", "scott", "scott");
4,创建一个Statement对象。
Statement stmt = conn.createStatement();
5,执行一个查询并返回一个结果。
ResultSet rs = stmt .executeUpdate(sql语句);
6,处理结果。
if (rs.next()) {
String firstName = rs.getString(1);
String lastName = rs.getString(2);
String title = rs.getString(3);
int salary = rs.getInt(4);
}
7、8,关闭连接,主要是:conn ,stmt ,rs
下面再看一段最简单且不规范的程序。
package com.yfy;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class jdbcTest {
private static String sql = "select * from EMPLOYEES where first_name=?";
public static void main(String[] args) throws SQLException {
//1,注册驱动
DriverManager.registerDriver(new oracle.jdbc.driver.OracleDriver());
//2,建立连接
Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:orcl", "scott", "scott");
//3,创建语句
Statement stmt = conn.createStatement();
//4,执行语句,返回结果集
ResultSet rs = stmt.executeQuery(sql);
//5,处理结果
while (rs.next()) {
System.out.println("id:" + rs.getInt("EMPLOYEE_ID") + " first_name:" + rs.getString("first_name"));
}
//6,关闭连接
rs.close();
stmt.close();
conn.close();
}
}
看看数据库中的内容
执行之后的结果:
主要过程就是这些 ,但是需要注意,这些代码以后再优化,现在只是强调一个过程。下面这张图可以清晰的表达代码的流程。其中有些以后在介绍。