您的位置:首页 > 其它

JDBC事务控制

2018-03-11 17:31 363 查看
默认是自动事务:

    执行sql语句:executeUpdate()  ---- 每执行一次executeUpdate方法代表事务自动提交。
通过jdbc的API手动事务:
    开启事务:conn.setAutoComnmit(false);
    提交事务:conn.commit();
    回滚事务:conn.rollback();

package connection;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

public class JdbcDemo {
public static void main(String[] args) {

// 1.注册驱动
Connection conn=null;

try {
Class.forName("com.mysql.jdbc.Driver");

// 2.获取连接connection
conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/web13?useSSL=false", "root", "906722");
conn.setAutoCommit(false);

// 3.取得statement
Statement stmt = conn.createStatement();

// 4.执行sql
stmt.executeUpdate("update user set name='bbb' where username='aaaa'	");
conn.commit();

// 5.关闭资源
stmt.close();
conn.close();
} catch (Exception e) {
try {
conn.rollback();
} catch (SQLException e1) {
e1.printStackTrace();
}			e.printStackTrace();
}
}
}
    执行sql语句:executeUpdate()  ---- 每执行一次executeUpdate方法代表事务自动提交。
通过jdbc的API手动事务:
    开启事务:conn.setAutoComnmit(false);
    提交事务:conn.commit();
    回滚事务:conn.rollback();

注意:控制事务的connnection必须是同一个! 
        执行sql的connection与开启事务的connnection必须是同一个才能对事务进行控制

    执行sql语句:executeUpdate()  ---- 每执行一次executeUpdate方法代表事务自动提交。
通过jdbc的API手动事务:
    开启事务:conn.setAutoComnmit(false);
    提交事务:conn.commit();
    回滚事务:conn.rollback();
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  jdbc事务控制