JDBC的全称是Java Database Connectivity,即Java数据库连接,它是一种可以执行SQL语句的Java API。通过使用JDBC,就可以使用同一种API访问不同的数据库系统。 换言之,有了JDBC API,就不必为了访问Sybase 数据库学习一组API,为访问Oracel数据库又学习一组API…..开发人员面向JDBC API编写应用程序,然后根据不同的数据库,使用不同的数据库驱动程序即可。
一. JDBC常用接口和类
JDBC API由以下常用的接口和类组成。
DriverManager :用于管理JDBC驱动的服务类。程序中使用该类的主要功能是获取Connection对象。
Connection:代表数据库连接对象,每个Connection代表一个物理连接会话。要想访问数据库,必须先获得数据库连接。
Statement: 用于执行SQL语句的工具接口。即只有获得了Statement之后才可执行SQL语句。当执行SQL查询时,返回查询到的结果集。
ResultSet :结果集对象。该对象包含访问查询结果的方法。
二. JDBC编程步骤
1) 加载数据库驱动。通常我们使用Class类的forName()静态方法来加载驱动。例如如下代码:
//加载驱动
Class.forName(driverClass);
上面代码中的driverClass就是数据库驱动类所对应的字符串。例如,加载MySQL的驱动采用如下代码:
//加载MySQL的驱动
Class.forName(“com.mysql.jdbc.Driver”);
而加载Oracle的驱动则采用如下代码:
//加载Oracle的驱动
Class.forName(“oracle.jdbc.driver.OracleDriver”);
2) 通过DriverManager获取数据库连接.DriverManager提供如下方法:
//获取数据库连接
DriverManager.getConnection(String url, String user , String pass);
当使用DriverManager获取数据库连接时,通常需要传入3个参数:数据库URL、登陆数据库的用户名和密码。
MySQL数据库的URL写法如下:
jdbc:mysql://hostname:port/databasename
3) 通过Connection对象创建Statement对象。
createStatement() :创建基本的Statement对象
4) 使用Statement执行SQL语句。通常使用如下2个方法来执行SQL语句:
executeQuery() :只能执行查询语句,执行后返回代表查询结果的ResultSet对象。
executeUpdate() :主要用于执行操作语句(insert、update、delete)和定义语句(create、alter、drop、truncate)
5) 操作结果集。如果执行的SQL语句是查询语句,则执行结果将返回一个ResultSet对象,该对象里保存了SQL语句查询的结果。程序可以通过操作该ResultSet对象来取出查询结果。
6) 回收数据库资源,包括关闭ResultSet、Statement和Connection 等资源。
例:
public class ConnMySql{
public static void main(String[] args){
//1.加载驱动
Class.forName("com.mysql.jdbc.Driver");
try{
//2.使用DriverManger获取数据库连接
//返回的Connection代表了Java程序和数据库的连接
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/atm","root","root");
//3.使用Connection来创建一个Statement对象
Statement stmt = conn.createStatement();
//4.执行SQL语句
ResultSet rs = stmt.executeQuery("select* from account");
//当结果集rs.next()的内容不为空,一直执行
while(rs.next()){
System.out.println(rs.getString(1)+"\t"+rs.getString(2));
}
}
}
}