91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用Java怎么處理mysql事務

發布時間:2021-04-07 16:51:34 來源:億速云 閱讀:488 作者:Leah 欄目:編程語言

本篇文章給大家分享的是有關使用Java怎么處理mysql事務,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

1、事務是一組要么同時執行成功,要么同時執行失敗的sql語句。是數據庫操作的一個執行單元。

2、事物的四大特點:

(1)atomicity(原子性)表示一個事務內的所有操作是一個整體,要么全部成功,要么全部失敗。

(2)consistency(一致性)表示一個事物內有一個操作失敗時,所有更改過的數據都必須回滾到修改前的狀態。

(3)isolation(隔離性)事務查看數據時數據所處的狀態,要么是另一并發事務修改它之前的狀態,要么是另一事務修改它之后的狀態,事務不會查看中間狀態的數據。

(4)durability(持久性)持久性事務完成之后,他對于系統的影響是永久性的。

3、實例(以sql語句中的insert語句為例)

package com.test.jdbc;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
/**
 * 事務的基本用法
 *
 */
public class Test {
  public static void main(String[] args) {
    Connection conn = null;
    PreparedStatement ps1 = null;
    PreparedStatement ps2 = null;
    try {
      //加載驅動類
      Class.forName("com.mysql.jdbc.Driver");
      conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/testjdbc","root","123456");
      conn.setAutoCommit(false); //JDBC中默認是true,自動提交事務
      ps1 = conn.prepareStatement("insert into t_user (username,pwd) values (?,?)");//?是占位符
      ps1.setObject(1, "張三");
      ps1.setObject(2, "666666");
      ps1.execute();
      System.out.println("插入一個用戶張三");
      try {
        Thread.sleep(3000);
      } catch (InterruptedException e) {
        e.printStackTrace();
      }
      ps2 = conn.prepareStatement("insert into t_user (username,pwd) values (?,?)");
      ps2.setObject(1, "李四");
      ps2.setObject(2, "123456");
      ps2.execute();
      System.out.println("插入一個用戶李四");
      conn.commit();//提交事務
    } catch (ClassNotFoundException e) {
      e.printStackTrace();
      try {
        conn.rollback();//某一條數據添加失敗時,回滾
      } catch (SQLException e1) {
        e1.printStackTrace();
      }
    } catch (SQLException e) {
      e.printStackTrace();
    }finally{
      try {
        if(ps1!=null){
          ps1.close();
        }
      } catch (SQLException e) {
        e.printStackTrace();
      }
      try {
        if(conn!=null){
          conn.close();
        }
      } catch (SQLException e) {
        e.printStackTrace();
      }
    }
  }
}

這段代碼是正確的結果。運行結果:

插入一個用戶張三
(等待三秒后)
插入一個用戶李四

查看數據庫,插入了兩條數據。

接下來把數據庫中剛剛插入的兩條數據刪掉,然后把第二條sql語句改一下,讓他出錯,在第二條sql語句中去掉一個占位符:

ps2 = conn.prepareStatement("insert into t_user (username,pwd) values (?)");

運行結果:

插入一個用戶張三
(等待三秒后)
拋出錯誤了。。。。。。。。

以上就是使用Java怎么處理mysql事務,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

古丈县| 漳浦县| 偏关县| 孝感市| 罗城| 周宁县| 大同县| 通渭县| 恩平市| 武陟县| 景宁| 桂东县| 泊头市| 同心县| 资溪县| 宜宾县| 综艺| 奉新县| 双峰县| 玛多县| 准格尔旗| 阳西县| 浮梁县| 临澧县| 洪湖市| 靖安县| 泰州市| 芦溪县| 本溪市| 临漳县| 聂拉木县| 万盛区| 青州市| 乌兰察布市| 思茅市| 银川市| 锦屏县| 嫩江县| 仙居县| 商都县| 锡林浩特市|