【MySQL 05】使用Java對MySQL進行操作(建立資料庫)

黄舟
發布: 2017-02-04 11:52:15
原創
1277 人瀏覽過

JDBC連接資料庫:

1、載入JDBC驅動程式 
2、提供JDBC連線的URL 
3、建立資料庫的連線 
4、建立一個Statement 
5、執行SQL語句 
6、處理結果🜎J物件

1、載入JDBC驅動程式:

在連接資料庫之前,首先要載入想要連接的資料庫的驅動到JVM(Java虛擬機),這透過java.lang.Class類別的靜態方法


 //加载数据库驱动总共有三种方式:
 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

  • 連接URL定義了連接資料庫時的協定、子協定、資料來源識別。

  • MYSQL的JDBC URL 寫法:jdbc:mysql://主機名稱:連接埠號碼/資料庫名稱? user = 使用者名稱& password =密碼& useUnicode = true & characterEncoding = UTF8

  •  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

•要連接資料庫,需要向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() ;   
  }
登入後複製

4、建立一個Statement

•要執行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) ;
登入後複製

6、處理結果

兩種情況: 

1、執行更新回傳的是這次操作影響到的記錄數。 

2、執行查詢回傳的結果是一個ResultSet物件。 
• ResultSet包含所有符合SQL語句中條件的行,並且它透過一套get方法提供了對這些行中資料的存取。
• 使用結果集(ResultSet)物件的存取方法取得資料:

  while(rs.next()){   
         String name = rs.getString("name") ;   
         String pass = rs.getString(1) ; // 此方法比较高效   
  }   
    (列是从左到右编号的,并且从列1开始)
登入後複製

7、關閉JDBC物件

作業完成以後要把所有使用的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();
        }

    }

}
登入後複製

🎜🎜以上操作,對資料庫【SQL 05多相關內容請關注PHP中文網(www.php.cn)! 🎜🎜🎜🎜
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板