JDBC連接資料庫:
1、載入JDBC驅動程式
2、提供JDBC連線的URL
3、建立資料庫的連線
4、建立一個Statement
5、執行SQL語句
6、處理結果🜎J物件
//加载数据库驱动总共有三种方式: try{ //① Class.forName("com.mysql.jdbc.Driver") ; //② com.mysql.jdbc.Driver driver = new com.mysql.jdbc.Driver(); //③ new com.mysql.jdbc.driver(); }catch(ClassNotFoundException e){ System.out.println("找不到驱动程序类 ,加载驱动失败!"); e.printStackTrace() ; }成功載入後,會將Driver類別的實例註冊到DriverManager類別中。 2、提供JDBC連接的URL
String url = "jdbc:mysql://localhost:3306/samp_db?" + "user=root&password=mysql&useUnicode=true&characterEncoding=UTF8";3、建立資料庫連接•要連接資料庫,需要向java.sql.DriverManager請求並取得ConnectionConnection
•要連接資料庫,需要向java.sql.DriverManager請求並取得ConnectionConnection
就代表對象,該物件就代表一個資料庫的連線。
•使用DriverManager的getConnectin(String url , String username , String password )方法傳入指定的慾連接的數
String url = "jdbc:mysql://localhost:3306/test" ; String username = "root" ; String password = "root" ; try{ Connection con = DriverManager.getConnection(url , username , password ) ; }catch(SQLException se){ System.out.println("数据库连接失败!"); se.printStackTrace() ; }
•要執行SQL語句,必須取得java.javasql. ,Statement實例分為以下3 類型:
1、執行靜態SQL語句。通常透過Statement實例實現。 2、執行動態SQL語句。通常透過PreparedStatement實例實現。
3、執行資料庫預存程序。通常透過CallableStatement實例實現。
Statement stmt = con.createStatement() ; PreparedStatement pstmt = con.prepareStatement(sql) ; CallableStatement cstmt = con.prepareCall("{CALL demoSp(? , ?)}") ;5、執行SQL語句Statement介面提供了三種執行SQL語句的方法:executeQuery 、executeUpdate 和execute
1、ResultSet executeQuery(String sqlString):執行一個查詢資料庫的字集( ResultSet)物件。
2、int executeUpdate(String sqlString):用於執行INSERT、UPDATE或DELETE語句以及SQL DDL語句,如:CREATE TABLE和DROP TABLE等
3、execute(sqlString):用於執行傳回多個結果集、多個更新計數或二者組合的語句。
ResultSet rs = stmt.executeQuery("SELECT * FROM ...") ; int rows = stmt.executeUpdate("INSERT INTO ...") ; boolean flag = stmt.execute(String sql) ;
兩種情況:
1、執行更新回傳的是這次操作影響到的記錄數。2、執行查詢回傳的結果是一個ResultSet物件。
• ResultSet包含所有符合SQL語句中條件的行,並且它透過一套get方法提供了對這些行中資料的存取。
• 使用結果集(ResultSet)物件的存取方法取得資料:
while(rs.next()){ String name = rs.getString("name") ; String pass = rs.getString(1) ; // 此方法比较高效 } (列是从左到右编号的,并且从列1开始)
作業完成以後要把所有使用的JDBC物件全都關閉,以釋放JDBC資源,關閉順序和宣告順序相反:
1、關閉記錄集 2、關閉聲明
3、關閉連接對象
if(rs != null){ // 关闭记录集 try{ rs.close() ; }catch(SQLException e){ e.printStackTrace() ; } } if(stmt != null){ // 关闭声明 try{ stmt.close() ; }catch(SQLException e){ e.printStackTrace() ; } } if(conn != null){ // 关闭连接对象 try{ conn.close() ; }catch(SQLException e){ e.printStackTrace() ; } }完整程序:
package org.Mysql; import java.sql.Connection;import java.sql.DriverManager; import java.sql.ResultSet;import java.sql.SQLException; import java.sql.Statement;public class mysqlDemo { public static void main(String[] args) throws Exception { //使用connection进行数据库的连接,创建一个connection对象,用于数据库的连接 Connection conn = null; String sql; // MySQL的JDBC URL编写方式:jdbc:mysql://主机名称(localhost):连接端口(3306)/数据库的名称?参数=值 // 指定数据库的用户名和密码 // 避免中文乱码要指定useUnicode和characterEncoding // 执行数据库操作之前要在数据库管理系统上创建一个数据库,名字自己定 // 下面语句之前就要先创建samp_db数据库 String url = "jdbc:mysql://localhost:3306/samp_db?" + "user=root&password=mysql&useUnicode=true&characterEncoding=UTF8"; try { // 之所以要使用下面这条语句,是因为要使用MySQL的驱动,所以我们要把它驱动起来, // 可以通过Class.forName把它加载进去,也可以通过初始化来驱动起来,下面三种形式都可以 // 动态加载mysql驱动 Class.forName("com.mysql.jdbc.Driver"); // or: // com.mysql.jdbc.Driver driver = new com.mysql.jdbc.Driver(); // or: // new com.mysql.jdbc.Driver(); System.out.println("成功加载MySQL驱动程序"); // 一个Connection代表一个数据库连接 conn = DriverManager.getConnection(url); // Statement里面带有很多方法,比如executeUpdate可以实现插入,更新和删除等 Statement stmt = conn.createStatement(); sql = "create table student(NO char(20),name varchar(20),primary key(NO))"; int result = stmt.executeUpdate(sql);// executeUpdate语句会返回一个受影响的行数,如果返回-1就没有成功 if (result != -1) { System.out.println("创建数据表成功"); sql = "insert into student(NO,name) values('2012001','陶伟基')"; result = stmt.executeUpdate(sql); sql = "insert into student(NO,name) values('2012002','周小俊')"; result = stmt.executeUpdate(sql); sql = "select * from student"; ResultSet rs = stmt.executeQuery(sql);// executeQuery会返回结果的集合,否则返回空值 System.out.println("学号\t姓名"); while (rs.next()) { System.out .println(rs.getString(1) + "\t" + rs.getString(2));// 入如果返回的是int类型可以用getInt() } } } catch (SQLException e) { System.out.println("MySQL操作错误"); e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } finally { conn.close(); } } }