1:先对一些概念的理解:
JDBC:Java DataBase Connection
本季目标
1、JDBC的分类
2、JDBC的主要操作类和接口: DriverManager、Connection、Statement、PreparedStatement、ResultSet
3、如何使用JDBC连接MySQL数据库
1、什么是JDBC?
JDBC是JAVA提供的一个服务,专门用于访问数据库操作,而且注意:JDBC定义的是一个数据库访问的标准,所以里面基本上都是一系列的接口。各个数据库厂商如果要想支持JDBC操作,则肯定要提供一组相关的类,这些类肯定都是提供接口子类实现。
2、JDBC的分类
·JDBC-ODBC桥连接
·JDBC直接连接
·JDBC网络连接
3、什么是ODBC?
ODBC是微软公司定义的一个开放式数据库连接(Open DataBase Connection),使用ODBC可以连接各种数据库(前提:必须在windows中安装好驱动才可以)。在SUN 的JDK中默认提供了此数据库的驱动程序,所以JDK本身可以直接使用JDBC-ODBC进行访问。
访问的过程:
JDBC --> ODBC --> 数据库 (性能比较低)
如果直接使用JDBC访问,访问过程:JDBC --> 数据库(性能较高)
4、主要操作接口
· Connection:表示连接数据库的接口
· Statement:表示操作数据库的接口(执行SQL语句)
|- PreparedStatement:操作SQL语句,但是可以进行预处理操作。
· ResultSet:表示查询之后的返回结果
5、使用JDBC-ODBC操作Access数据库
新建一个access 数据库:
新建一个access, 命名:mydb.mdb -------- 建立一张person表:id:自动增长;name:姓名;age:年龄
因为我们的目的是使用JDBC-ODBC桥连接操作数据库,所以此处必须先配置ODBC数据源:管理工具 --> 数据源
添加一个数据源是:Ms Access Diver(*.mdb)
在ODBC上设置了一个数据库的别名,此别名testDB代表mydb.mdb。以后在操作的时候就是使用testDB即可。
保存并关闭access数据库
1、操作数据库的步骤(JDBC) · 加载数据库的驱动程序:Class.forName("驱动程序") ;
· 通过连接管理器,取得一个数据库的连接:DriverManager.getConnection(连接地址)
· 通过连接创建数据库的操作对象:Statement
· 操作数据库 --> 执行SQL语句
· 关闭数据库操作
有些数据可以直接从键盘上输入
package org.sunxin.struts2.ch02.action;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class JDBCDemo02 {
public static final String DBDRIVE = "sun.jdbc.odbc.JdbcOdbcDriver";
public static final String DBURL = "jdbc:odbc:testDB";
public static void main(String[] args){
String name = null;
int age = 0;
BufferedReader buf = new BufferedReader(new InputStreamReader(System.in));
System.out.println("请输入姓名:");
try{
name = buf.readLine();
}catch (IOException e1){
e1.printStackTrace();
}
System.out.println("请输入年龄:");
try{
age = Integer.parseInt(buf.readLine());
}catch (IOException e1){
e1.printStackTrace();
}
Connection conn = null;
Statement stmt = null;
try{
Class.forName(DBDRIVE);
}catch (ClassNotFoundException e){
e.printStackTrace();
}
try {
conn = DriverManager.getConnection(DBURL);
}catch (SQLException e){
e.printStackTrace();
}
String sql = "INSERT INTO person(name,age) VALUES ('"+name+"',"+age+")";
System.out.println(sql);
try{
stmt = conn.createStatement();
}catch(SQLException e){
e.printStackTrace();
}
try{
stmt.executeUpdate(sql);
}catch(SQLException e){
e.printStackTrace();
}
try {
stmt.close();
conn.close();
}catch(SQLException e){
e.printStackTrace();
}
}
}
注意:
在插入的程序处实际上存在了一点问题:
例如:现在要输入姓名为:Mr'Wang
INSERT INTO person(name,age) VALUES ('Mr'Wang',30)
一般来说在使用JDBC 操作数据库的时候,往往很少会去使用Statement 进行操作,而经常使用Statement的子接口PreparedStatement进行操作。
PreparedStatement 是预处理,表示先在数据库中插入一条信息,但是信息的内容暂时不确定,等待用户通过专门的方法进行插入。
JDBCDemo05:
package com.redking.jdbc.demo;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
public class JDBCDemo05 {
public static final String DBDRIVER = "sun.jdbc.odbc.JdbcOdbcDriver";
public static final String DBURL = "jdbc:odbc:testDB";
public static void main(String[] args) {
String name = null;
int age = 0;
BufferedReader buf = new BufferedReader(new InputStreamReader(System.in));
System.out.println("请输入姓名:");
try {
name = buf.readLine();
} catch (IOException e1) {
e1.printStackTrace();
}
System.out.println("请输入年龄:");
try {
age = Integer.parseInt(buf.readLine());
} catch (NumberFormatException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
//数据库连接对象
Connection conn = null;
//数据库操作对象
PreparedStatement pstmt = null;
//1、加载驱动程序
try {
Class.forName(DBDRIVER);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
//2、连接数据库
//通过连接管理器连接数据库
try {
conn = DriverManager.getConnection(DBURL);
} catch (SQLException e) {
e.printStackTrace();
}
//3、向数据库中插入一条数据
String sql = "INSERT INTO person(name,age) VALUES (?,?)";
System.out.println(sql);
try {
//现在暂时占着,只是还不执行哈~
pstmt = conn.prepareStatement(sql);
} catch (SQLException e) {
e.printStackTrace();
}
//4、执行语句
//执行语句之前必须设置内容
try {
//设置好内容
pstmt.setString(1,name);
pstmt.setInt(2, age);
//执行数据库更新操作
pstmt.executeUpdate();
} catch (SQLException e) {
e.printStackTrace();
}
//5、关闭操作,步骤相反哈~
try {
pstmt.close();
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
一般在实际的开发中都去使用PreparedStatement,而很少会有人去直接使用Statement进行操作。
进行查询:
一般查询指的是执行SELECT 语句,SELECT 语句执行后实际上是会返回一组的数据(在内存中保存的)。
必须使用ResultSet接口进行接收,实际此处也不是很清楚会有多行数据。
Next()表示把指针向下移动一个位置。
JDBCDemo06:
package com.redking.jdbc.demo;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class JDBCDemo06 {
public static final String DBDRIVER = "sun.jdbc.odbc.JdbcOdbcDriver";
public static final String DBURL = "jdbc:odbc:testDB";
public static void main(String[] args) {
//数据库连接对象
Connection conn = null;
//数据库操作对象
PreparedStatement pstmt = null;
//数据库查询结果集对象
ResultSet rs = null;
//1、加载驱动程序
try {
Class.forName(DBDRIVER);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
//2、连接数据库
//通过连接管理器连接数据库
try {
conn = DriverManager.getConnection(DBURL);
} catch (SQLException e) {
e.printStackTrace();
}
//3、向数据库中插入一条数据
//查询全部数据,查询数据的时候绝对不要写“*”
String sql = "SELECT id,name,age FROM person";
System.out.println(sql);
try {
//现在暂时占着,只是还不执行哈~
pstmt = conn.prepareStatement(sql);
} catch (SQLException e) {
e.printStackTrace();
}
//4、执行语句
//执行语句之前必须设置内容
try {
//执行数据库查询操作,返回的结果全部放在ResultSet之中
rs = pstmt.executeQuery();
} catch (SQLException e) {
e.printStackTrace();
}
//下面开始依次循环取出内容,先判断后面有没内容,如果有则输出哈~
try {
while(rs.next()){
//Result必须按类型取值
int id = rs.getInt("id");
String name = rs.getString("name");
int age = rs.getInt("age");
System.out.println("ID = "+id+";name = "+name+";age = "+age);
}
} catch (SQLException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
//5、关闭操作,步骤相反哈~
try {
rs.close();
pstmt.close();
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
总结JDBC操作数据库的整体步骤:
1、加载驱动程序:
|- Class.forName("sun.jdbc.odbc.JdbcOdbcDriver") ;
2、连接数据库:
|- Connection conn = DriverManager.getConnection("jdbc:odbc:testDB") ;
3、实例化操作对象: |- Statement stmt = conn.createStatement() ; --> 本身是没有SQL语句的
|- PreparedStatement pstmt = conn.prepareStatement(sql) ; --> 在实例化时必须有SQL语句
4、进行数据库的CRUD操作
|- Statement
|- 更新:public int executeUpdate(sql)
|- 查询:public ResultSet executeQuery(sql)
|- PreparedStatement
|- 更新:先进行设置值(setXxx()),public int executeUpdate()
|- 查询:public ResultSet executeQuery() ;
|- ResulSet:
|- 所有的查询记录全部放在此对象之中,通过getXxx()方法取得
|- 取得的时候可以直接写入列的名称
|- 也可以写入编号
5、关闭操作:先开后关的原则 |- 如果有查询,则先关闭查询
|- 关闭操作对象(PreparedStatement)
|- 关闭数据库的连接