SQL提交不起作用

时间:2018-07-21 04:34:30

标签: mysql commit rollback

我正在尝试使用回滚返回到我提交的前一条语句,但是它不起作用,它始终显示当前语句。这意味着提交不起作用?我该怎么解决?

drop table departments_dup;
create table departments_dup
(
 dept_no char(4),
 dept_name varchar(40)
 );

insert into departments_dup
select * from departments;

SELECT 
    *
FROM
    departments_dup
ORDER BY dept_no;

commit;

UPDATE departments_dup 
SET 
    dept_name = 'Quality Control',
    dept_no = 'd021';

ROLLBACK;

1 个答案:

答案 0 :(得分:2)

默认情况下,mysql自动提交true,因此您可以在句子之前打开事务并提交到结尾;

START TRANSACTION;
UPDATE departments_dup 
  SET 
  dept_name = 'Quality Control',
  dept_no = 'd021';

ROLLBACK;

或者您可以将autocommit设置为false,将以下内容添加到 my.cnf 文件的[mysqld]部分。

init_connect='set autocommit=0'

这会将每个客户端的自动提交设置为关闭。