트랜잭션 트랜잭션은 데이터베이스의 다양한 데이터 항목을 업데이트할 수 있는 프로그램 실행 단위에 액세스합니다.
트랜잭션은 트랜잭션 시작(begin transaction)과 트랜잭션 종료(end transaction) 사이에 수행되는 모든 작업으로 구성됩니다. )
MySQL은 트랜잭션의 통합 관리(스토리지 엔진 innodb)를 허용하고 사용자가 수행한 작업을 임시로 저장하며 이를 데이터 테이블에 직접 입력(업데이트)하지 않습니다.
트랜잭션은 일반적으로 자동으로 제출되거나 수동으로 제출될 수 있습니다
클라이언트가 서버에 SQL 명령(쓰기 작업, 추가, 삭제, 수정)을 보내면 서버는 사용자 피드백을 기다리지 않고 실행 후 자동으로 결과를 서버에 동기화합니다. 데이터 테이블
두 클라이언트, 한 클라이언트는 SQL 명령을 실행하고 다른 클라이언트는 실행 결과를 봅니다.
변수를 통해 자동 트랜잭션 제어
mysql> show variables like 'autocommit'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | autocommit | ON | +---------------+-------+ -- 关闭自动事务 set autocommit = off; mysql> show variables like 'autocommit'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | autocommit | OFF | +---------------+-------+
자동 트랜잭션 종료 후 한 클라이언트는 데이터를 수정하고 다른 클라이언트는 결과를 읽습니다. 수정 결과를 찾을 수 없습니다
자동 트랜잭션이 꺼지면 사용자는 동기화 여부
커밋 커밋( 데이터 테이블에 동기화하면 트랜잭션이 지워집니다)
롤백 롤백(이전 작업 지우기, 더 이상 없음)
-- 客户端A关闭自动事务后操作数据 mysql> select * from my_class; +----+--------+ | id | name | +----+--------+ | 1 | 一班 | | 3 | 三班 | +----+--------+ 2 rows in set (0.01 sec) mysql> insert into my_class (name) values('四班'); Query OK, 1 row affected (0.00 sec) mysql> select * from my_class; +----+--------+ | id | name | +----+--------+ | 1 | 一班 | | 3 | 三班 | | 5 | 四班 | +----+--------+ 3 rows in set (0.00 sec) -- 客户端B看不到新增的 四班数据, mysql> select * from my_class; +----+--------+ | id | name | +----+--------+ | 1 | 一班 | | 3 | 三班 | +----+--------+ 2 rows in set (0.00 sec)
클라이언트 A가 커밋을 실행하고 트랜잭션을 제출한 후 클라이언트 B는 새 데이터를 볼 수 있습니다
일반적으로 자동 거래를 비활성화할 필요는 없습니다. 거래를 사용해야 하는 경우 수동 거래를 사용하세요.
사용자가
수동 달성을 위해 거래 작업 지침을 수동으로 보내야 합니다. 트랜잭션 지침
-- 1、开启事务,从这条语句开始,后面所有的语句都不会直接写入到数据表,保存在事务日志中 start transaction -- 2、事务处理,多个指令构成 -- 3、事务提交,结束事务 commit / rollback
mysql> select * from my_class; +----+--------+ | id | name | +----+--------+ | 1 | 一班 | | 3 | 三班 | | 5 | 四班 | +----+--------+ 3 rows in set (0.04 sec) mysql> select * from my_student; +----+--------+----------+------+--------+ | id | name | class_id | age | gender | +----+--------+----------+------+--------+ | 1 | 刘备 | 1 | 18 | 2 | | 2 | 李四 | 1 | 19 | 1 | | 3 | 王五 | NULL | 20 | 2 | | 4 | 张飞 | NULL | 21 | 1 | | 5 | 关羽 | NULL | 22 | 2 | | 6 | 曹操 | 1 | 20 | NULL | +----+--------+----------+------+--------+ 6 rows in set (0.00 sec) -- 开启事务 start transaction; -- 执行事务操作,多个修改操作 insert into my_class (name)values ('六班'); insert into my_student (name, class_id, age, gender)values ('司马懿', 6, 26, 1); -- 提交事务 commit; -- 或者回滚操作,所有数据无效清空 rollback;
연속적인 트랜잭션 작업이 있을 때 단계는 다음과 같습니다. 성공하면 다시 시작할 필요가 없습니다. 마크(롤백 포인트)를 설정할 수 있습니다. 특정 시점에 있다가 나중에 장애가 발생하면 이 표시의 위치로 돌아갈 수 있습니다
-- 增加回滚点 savepoint 回滚点名字; -- 回到回滚点 清空之后所有操作 rollback to 回滚点名字;
거래 중에 Step이 많으면 여러 개의 롤백 지점을 설정할 수 있습니다
ACID :
원자성 트랜잭션은 분할할 수 없는 작업 단위입니다. 모두 완료되거나 아무것도 완료되지 않습니다.
일관성 트랜잭션 데이터베이스를 하나의 일관성 상태에서 다른 일관성 상태로 변경해야 합니다
격리 트랜잭션 실행은 다른 트랜잭션에 의해 방해받을 수 없습니다. 데이터를 운영할 때 데이터는 잠깁니다.
지속성 내구성 트랜잭션이 제출되면 데이터베이스의 데이터 변경 사항은 영구적입니다.
인덱스가 조건에 사용되면 레코드가 격리됩니다. 그렇지 않으면 전체 테이블 검색을 통해 전체 테이블이 잠깁니다
위 내용은 MySQL 트랜잭션 보안을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!