我正在尝试使用回滚返回到我提交的前一条语句,但是它不起作用,它始终显示当前语句。这意味着提交不起作用?我该怎么解决?
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;
答案 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'
这会将每个客户端的自动提交设置为关闭。