在Java程式設計中,以下範例使用connect.commit()
方法來提交事務執行查詢。假定資料庫名稱是:testdb
,其中有兩張表:employee
和dept
,employee
表中有4
條記錄,dept
表中有2
條記錄。
建立資料庫表的語句 -
use testdb;
-- 員工表
drop table if exists employees;
create table if not exists employees (
id int not null primary key,
age int not null,
name varchar(64),
dept_id int(10)
);
INSERT INTO employees VALUES (100, 28, 'MaxSu', 1);
INSERT INTO employees VALUES (101, 25, 'WeiWang', 2);
INSERT INTO employees VALUES (102, 30, 'KidaSu', 2);
INSERT INTO employees VALUES (103, 28, 'KobeBryant', 1);
----
-- 部門表
drop table if exists dept;
create table if not exists dept (
id int not null primary key,
name varchar (64)
);
INSERT INTO dept VALUES (1, '技術部');
INSERT INTO dept VALUES (2, '市場部');
以下範例使用connect.commit()
方法來執行提交事務和查詢語句。
package com.yiibai;
import java.sql.*;
public class CommitStatement {
public static void main(String[] args) throws Exception {
String JDBC_DRIVER = "com.mysql.jdbc.Driver";
String DB_URL = "jdbc:mysql://localhost/testdb?useSSL=false";
String User = "root";
String Passwd = "123456";
try {
Class.forName(JDBC_DRIVER);
} catch (ClassNotFoundException e) {
System.out.println("Class not found " + e);
}
Connection con = DriverManager.getConnection(DB_URL, User, Passwd);
con.setAutoCommit(false);
Statement stmt = con.createStatement();
String createTable = "CREATE TABLE `employees` ( `id` int(11) NOT NULL, `age` int(11) NOT NULL,`name` varchar(64) DEFAULT NULL,`dept_id` int(10) DEFAULT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;";
String query = "insert into employees(id, name,age,dept_id) values(1,'Maxsu', 27, 1)";
String query1 = "insert into employees(id, name,age,dept_id) values(5,'蘇小牛', 24, 2)";
String query2 = "select * from employees";
// 建立表
stmt.execute(createTable);
con.commit();
ResultSet rs = stmt.executeQuery(query2);
int no_of_rows = 0;
while (rs.next()) {
no_of_rows++;
}
System.out.println("No. of rows before commit statement = " + no_of_rows);
con.setAutoCommit(false);
stmt.execute(query1);
stmt.execute(query);
con.commit();
rs = stmt.executeQuery(query2);
no_of_rows = 0;
while (rs.next()) {
no_of_rows++;
}
System.out.println("No. of rows after commit statement = " + no_of_rows);
}
}
上述程式碼範例將產生以下結果。
No. of rows before commit statement = 0
No. of rows after commit statement = 2
註:如果JDBC驅動程式安裝不正確,將獲得
ClassNotfound
異常。
Class not found java.lang.ClassNotFoundException: com.mysql.jdbc.Driver
JDBC Class found
SQL exception occuredjava.sql.SQLException: No suitable driver found for jdbc:mysql://localhost/testdb