>  기사  >  데이터 베이스  >  MySQL 트랜잭션 보안을 구현하는 방법

MySQL 트랜잭션 보안을 구현하는 방법

PHPz
PHPz앞으로
2023-05-29 10:04:071303검색

트랜잭션 보안 트랜잭션

트랜잭션 트랜잭션은 데이터베이스의 다양한 데이터 항목을 업데이트할 수 있는 프로그램 실행 단위에 액세스합니다.

트랜잭션은 트랜잭션 시작(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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제