JAVA采用JDBC连接操作数据库详解

JDBC连接数据库概述

一、JDBC基础知识

JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成。JDBC为数据库开发人员提供了一个标准的API,据此可以构建更高级的工具和接口,使数据库开发人员能够用纯 Java API 编写数据库应用程序,并且可跨平台运行,并且不受数据库供应商的限制。

1、跨平台运行:这是继承了Java语言的“一次编译,到处运行”的特点;

2、不受数据库供应商的限制:巧妙在于JDBC设有两种接口,一个是面向应用程序层,其作用是使得开发人员通过SQL调用数据库和处理结果,而不需要考虑数据库的提供商;另一个是驱动程序层,处理与具体驱动程序的交互,JDBC驱动程序可以利用JDBC API创建Java程序和数据源之间的桥梁。应用程序只需要编写一次,便可以移到各种驱动程序上运行。Sun提供了一个驱动管理器,数据库供应商——如MySQL、Oracle,提供的驱动程序满足驱动管理器的要求就可以被识别,就可以正常工作。所以JDBC不受数据库供应商的限制。

JDBC API可以作为连接Java应用程序与各种关系数据库的纽带,在带来方便的同时也有负面影响,以下是JDBC的优、缺点。优点如下:

操作便捷:JDBC使得开发人员不需要再使用复杂的驱动器调用命令和函数;

可移植性强:JDBC支持不同的关系数据库,所以可以使同一个应用程序支持多个数据库的访问,只要加载相应的驱动程序即可;

通用性好:JDBC-ODBC桥接驱动器将JDBC函数换成ODBC;

面向对象:可以将常用的JDBC数据库连接封装成一个类,在使用的时候直接调用即可。

缺点如下:

访问数据记录的速度受到一定程度的影响;

更改数据源困难:JDBC可支持多种数据库,各种数据库之间的操作必有不同,这就给更改数据源带来了很大的麻烦

二、JDBC连接数据库的流程及其原理

创建一个以JDBC连接数据库的程序,包含7个步骤:

1、加载JDBC驱动程序:

在连接数据库之前,首先要加载想要连接的数据库的驱动,就是数据库厂商提供的jar包,将它加载到JVM(Java虚拟机)中,这通过java.lang.Class类的静态方法forName(String className)实现。

例如:

01
try{
02
 
03
//加载MySql的驱动类 
04
//不同的数据库提供的驱动包是不一样的,在下面大家将会看到常用的驱动类。
05
Class.forName("com.mysql.jdbc.Driver") ; 
06
System.out.println("成功加载驱动");
07
 
08
}catch(ClassNotFoundException e){
09
 
10
System.out.println("找不到驱动程序类 ,加载驱动失败!");
11
 
12
e.printStackTrace() ;
13
 
14
}

成功加载后,会将Driver类的实例注册到DriverManager类中,我们在下一步中,就可以直接调用类中的方法。

2、提供JDBC连接的URL

•连接URL定义了连接数据库时的协议、子协议、数据源标识。

•书写形式:协议:子协议:数据源标识

协议:在JDBC中总是以jdbc开始

子协议:是桥连接的驱动程序或是数据库管理系统名称。

数据源标识:标记找到数据库来源的地址与连接端口。

下面列出常用的数据库连接URL:

Oracle8/8i/9i数据库(thin模式)

1
Class.forName("oracle.jdbc.driver.OracleDriver").newInstance();
2
String url="jdbc:oracle:thin:@localhost:1521:orcl";
3
//orcl为数据库的SID

DB2数据库

1
Class.forName("com.ibm.db2.jdbc.app.DB2Driver ").newInstance();
2
String url="jdbc:db2://localhost:5000/sample";
3
//sample为你的数据库名

Sql Server7.0/2000数据库

1
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver").newInstance();
2
String url="jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=mydb";
3
//mydb为数据库

Sybase数据库

1
Class.forName("com.sybase.jdbc.SybDriver").newInstance();
2
String url =" jdbc:sybase:Tds:localhost:5007/myDB";
3
//myDB为你的数据库名

Informix数据库

1
Class.forName("com.informix.jdbc.IfxDriver").newInstance();
2
String url ="jdbc:informix-sqli://123.45.67.89:1533/myDB:INFORMIXSERVER=myserver;

MySQL数据库

1
Class.forName("com.mysql.jdbc.Driver").newInstance();
2
String url ="jdbc:mysql://localhost/myDB?user=soft&password=soft1234&useUnicode=true&characterEncoding=8859_1"
3
//myDB为数据库名

PostgreSQL数据库

1
Class.forName("org.postgresql.Driver").newInstance();
2
String url ="jdbc:postgresql://localhost/myDB"
3
//myDB为数据库名

说明:useUnicode=true:表示使用Unicode字符集。如果characterEncoding设置为gb2312或GBK,本参数必须设置为true 。aracterEncoding=gbk:字符编码方式。

3、创建数据库的连接

•要连接数据库,需要向java.sql.DriverManager请求并获得Connection对象,该对象就代表一个数据库的连接。

•使用DriverManager的getConnectin(String url , String username , String password )方法传入指定的欲连接的数据库的路径、数据库的用户名和密码来获得。

例如:

01
String url = "jdbc:mysql://localhost:3306/test" ;
02
 
03
String username = "root" ;
04
 
05
String password = "root" ;
06
 
07
try{
08
 
09
Connection con =
10
 
11
DriverManager.getConnection(url , username , password ) ;
12
 
13
}catch(SQLException se){
14
 
15
System.out.println("数据库连接失败!");
16
 
17
se.printStackTrace() ;
18
 
19
}

也可以不单独定义上面username和password,直接将用户名、密码附加在url上,作为参数发送给数据库服务器,例如

1
jdbc:mysql://localhost:3306/test?user=root&password=root

4、创建一个Statement

•要执行SQL语句,必须获得java.sql.Statement实例,Statement实例分为以下3

种类型:

1、执行静态SQL语句。通常通过Statement实例实现。

2、执行动态SQL语句。通常通过PreparedStatement实例实现。

3、执行数据库存储过程。通常通过CallableStatement实例实现。

具体的实现方式:

1
Statement stmt = con.createStatement() ; 
2
PreparedStatement pstmt = con.prepareStatement(sql) ; 
3
CallableStatement cstmt = con.prepareCall("{CALL demoSp(? , ?)}") ; 

5、执行SQL语句

Statement接口提供了三种执行SQL语句的方法:executeQuery 、executeUpdate

和execute

1、ResultSet executeQuery(String sqlString):执行查询数据库的SQL语句

,返回一个结果集(ResultSet)对象。

2、int executeUpdate(String sqlString):用于执行INSERT、UPDATE或

DELETE语句以及SQL DDL语句,如:CREATE TABLE和DROP TABLE等

3、execute(sqlString):用于执行返回多个结果集、多个更新计数或二者组合的

语句。

具体实现的代码:

1
ResultSet rs = stmt.executeQuery("SELECT * FROM ...") ; 
2
int rows = stmt.executeUpdate("INSERT INTO ...") ; 
3
boolean flag = stmt.execute(String sql) ; 

6、处理结果

两种情况:

1、执行更新返回的是本次操作影响到的记录数。

2、执行查询返回的结果是一个ResultSet对象。

• ResultSet包含符合SQL语句中条件的所有行,并且它通过一套get方法提供了对这些

行中数据的访问。

• 使用结果集(ResultSet)对象的访问方法获取数据:

1
while(rs.next()){
2
 
3
String name = rs.getString("name") ;
4
 
5
String pass = rs.getString(1) ; // 此方法比较高效
6
 
7
}

(列是从左到右编号的,并且从列1开始)

7、关闭JDBC对象

操作完成以后要把所有使用的JDBC对象全都关闭,以释放JDBC资源,关闭顺序和声

明顺序相反:

1、关闭记录集

2、关闭声明

3、关闭连接对象

01
if(rs != null){ // 关闭记录集
02
 
03
try{
04
     rs.close() ;
05
 
06
}catch(SQLException e){
07
 
08
     e.printStackTrace() ;
09
 
10
}   }
11
 
12
if(stmt != null){ // 关闭声明
13
 
14
try{
15
 
16
stmt.close() ;
17
 
18
}catch(SQLException e){
19
 
20
e.printStackTrace() ;
21
}     }
22
 
23
if(conn != null){ // 关闭连接对象
24
 
25
try{
26
 
27
conn.close() ;
28
 
29
}catch(SQLException e){
30
 
31
e.printStackTrace() ;
32
 
33
}    }
34

三、JDBC应用示例实验

实验使用mysql数据库,使用myeclipse工具新建一个类,命名为 JDBCTest,可以使用Navicat for MySQL可视化数据库操作,新建数据库users,在数据库users里添加 表user_table( UserId,UserName,PassWord)),有三个字段,本示例主要用于演示数据库连接,连接成功后,插入一条数据。具体内容如下

01
import java.sql.*;
02
public class JDBCTest {
03
 
04
/**
05
* @param args
06
* @throws ClassNotFoundException 
07
* @throws SQLException 
08
*/
09
public static void main(String[] args) throws ClassNotFoundException, SQLException {
10
//第一步:打开数据库 需要用户名,密码,数据库地址,数据库名称;
11
String username = "root";
12
String password = "123456";
13
 
14
String url = "jdbc:mysql://localhost:3306/users";
15
//1.加载数据库驱动
16
Class.forName("com.mysql.jdbc.Driver");
17
//2.创建是数据库连接
18
Connection conn = DriverManager.getConnection(url, username, password);
19
 
20
System.out.println("数据库连接成功!");
21
//第二步:操作数据库;
22
String sql=" insert into user_table ( UserId,UserName,PassWord) values (5,'song','ss') ";
23
PreparedStatement pt=conn.prepareStatement( sql );
24
pt.executeUpdate( );
25
//第三步:关闭数据库;
26
conn.close();
27
System.out.println("数据库操作成功!");
28
 
29
}
30
 
31
}

更多关于数据库的操作,如增删改查,参考网友sererin写的如下代码,很详细:

001

002
<PRE class=java name="code">package chp07;
003
 
004
import java.sql.Connection;
005
import java.sql.DriverManager;
006
import java.sql.ResultSet;
007
import java.sql.SQLException;
008
import java.sql.Statement;
009
 
010
public class JDBC_Test {
011
 // 创建静态全局变量
012
 static Connection conn;
013
 
014
 static Statement st;
015
 
016
 public static void main(String[] args) {
017
 insert(); //插入添加记录
018
 update(); //更新记录数据
019
 delete(); //删除记录
020
 query(); //查询记录并显示
021
 }
022
 
023
 /* 插入数据记录,并输出插入的数据记录数*/
024
 public static void insert() {
025
 
026
 conn = getConnection(); // 首先要获取连接,即连接到数据库
027
 
028
 try {
029
 String sql = "INSERT INTO staff(name, age, sex,address, depart, worklen,wage)"
030
 + " VALUES ('Tom1', 32, 'M', 'china','Personnel','3','3000')"; // 插入数据的sql语句
031
 
032
 st = (Statement) conn.createStatement(); // 创建用于执行静态sql语句的Statement对象
033
 
034
 int count = st.executeUpdate(sql); // 执行插入操作的sql语句,并返回插入数据的个数
035
 
036
 System.out.println("向staff表中插入 " + count + " 条数据"); //输出插入操作的处理结果
037
 
038
 conn.close(); //关闭数据库连接
039
 
040
 } catch (SQLException e) {
041
 System.out.println("插入数据失败" + e.getMessage());
042
 }
043
 }
044
 
045
 /* 更新符合要求的记录,并返回更新的记录数目*/
046
 public static void update() {
047
 conn = getConnection(); //同样先要获取连接,即连接到数据库
048
 try {
049
 String sql = "update staff set wage='2200' where name = 'lucy'";// 更新数据的sql语句
050
 
051
 st = (Statement) conn.createStatement(); //创建用于执行静态sql语句的Statement对象,st属局部变量
052
 
053
 int count = st.executeUpdate(sql);// 执行更新操作的sql语句,返回更新数据的个数
054
 
055
 System.out.println("staff表中更新 " + count + " 条数据"); //输出更新操作的处理结果
056
 
057
 conn.close(); //关闭数据库连接
058
 
059
 } catch (SQLException e) {
060
 System.out.println("更新数据失败");
061
 }
062
 }
063
 
064
 /* 查询数据库,输出符合要求的记录的情况*/
065
 public static void query() {
066
 
067
 conn = getConnection(); //同样先要获取连接,即连接到数据库
068
 try {
069
 String sql = "select * from staff"; // 查询数据的sql语句
070
 st = (Statement) conn.createStatement(); //创建用于执行静态sql语句的Statement对象,st属局部变量
071
 
072
 ResultSet rs = st.executeQuery(sql); //执行sql查询语句,返回查询数据的结果集
073
 System.out.println("最后的查询结果为:");
074
 while (rs.next()) { // 判断是否还有下一个数据
075
 
076
 // 根据字段名获取相应的值
077
 String name = rs.getString("name");
078
 int age = rs.getInt("age");
079
 String sex = rs.getString("sex");
080
 String address = rs.getString("address");
081
 String depart = rs.getString("depart");
082
 String worklen = rs.getString("worklen");
083
 String wage = rs.getString("wage");
084
 
085
 //输出查到的记录的各个字段的值
086
 System.out.println(name + " " + age + " " + sex + " " + address
087
 + " " + depart + " " + worklen + " " + wage);
088
 
089
 }
090
 conn.close(); //关闭数据库连接
091
 
092
 } catch (SQLException e) {
093
 System.out.println("查询数据失败");
094
 }
095
 }
096
 
097
 /* 删除符合要求的记录,输出情况*/
098
 public static void delete() {
099
 
100
 conn = getConnection(); //同样先要获取连接,即连接到数据库
101
 try {
102
 String sql = "delete from staff  where name = 'lili'";// 删除数据的sql语句
103
 st = (Statement) conn.createStatement(); //创建用于执行静态sql语句的Statement对象,st属局部变量
104
 
105
 int count = st.executeUpdate(sql);// 执行sql删除语句,返回删除数据的数量
106
 
107
 System.out.println("staff表中删除 " + count + " 条数据\n"); //输出删除操作的处理结果
108
 
109
 conn.close(); //关闭数据库连接
110
 
111
 } catch (SQLException e) {
112
 System.out.println("删除数据失败");
113
 }
114
 
115
 }
116
 
117
 /* 获取数据库连接的函数*/
118
 public static Connection getConnection() {
119
 Connection con = null; //创建用于连接数据库的Connection对象
120
 try {
121
 Class.forName("com.mysql.jdbc.Driver");// 加载Mysql数据驱动
122
 
123
 con = DriverManager.getConnection(
124
 "jdbc:mysql://localhost:3306/myuser", "root", "root");// 创建数据连接
125
 
126
 } catch (Exception e) {
127
 System.out.println("数据库连接失败" + e.getMessage());
128
 }
129
 return con; //返回所建立的数据库连接
130
 }
131
}
132
</PRE><BR>
133
<PRE></PRE>
134
<P></P>
135
<P><STRONG>项目部署到服务器,然后运行结果:</STRONG></P>
136
<P></P>
137
<PRE></PRE>
138
<PRE></PRE>
139
<PRE></PRE>
140
上一篇:Spring入门(10)-Spring JDBC


下一篇:浅谈JDBC编程