sql >> Database teknologi >  >> RDS >> Mysql

Hvorfor tillader MySQL eksplicit prædikatlåsning INSERT-sætninger uden for prædikatlåsen

SELECT FOR UPDATE låser mellem 1 og næste værdi i medarbejdertabellen. Da der ikke er nogen næste-værdi, låses den indtil supremum pseudo-record . Dette kan ses i information_schema.innodb_locks :

mysql> select * from innodb_locks;
+----------------+-------------+-----------+-----------+-------------------+------------+------------+-----------+----------+------------------------+
| lock_id        | lock_trx_id | lock_mode | lock_type | lock_table        | lock_index | lock_space | lock_page | lock_rec | lock_data              |
+----------------+-------------+-----------+-----------+-------------------+------------+------------+-----------+----------+------------------------+
| 28275:1448:3:1 | 28275       | X         | RECORD    | `test`.`employee` | PRIMARY    |       1448 |         3 |        1 | supremum pseudo-record |
| 28273:1448:3:1 | 28273       | X         | RECORD    | `test`.`employee` | PRIMARY    |       1448 |         3 |        1 | supremum pseudo-record |
+----------------+-------------+-----------+-----------+-------------------+------------+------------+-----------+----------+------------------------+
2 rows in set, 1 warning (0.00 sec)

Hvis du ændrer test-casen lidt, så der er en række i medarbejdere for dept-id=2, og derefter prøver at tilføje en medarbejder for dept-id=3, vil det virke. Eksempel:

create table department (
    id bigint not null, 
    budget bigint not null, 
    name varchar(255), 
    primary key (id)
) ENGINE=InnoDB;

create table employee (
    id bigint not null, 
    name varchar(255), 
    salary bigint not null, 
    department_id bigint, primary key (id)
) ENGINE=InnoDB;


alter table employee 
add constraint FK_department_id 
foreign key (department_id) 
references department (id);


insert into department (name, budget, id) 
values ('Hypersistence', 100000, 1);

insert into department (name, budget, id) 
values ('Bitsystem', 10000, 2);

insert into department (name, budget, id) 
values ('XX', 10000, 3);


insert into employee (department_id, name, salary, id) 
values (1, 'John Doe 0', 30000, 0);

insert into employee (department_id, name, salary, id) 
values (1, 'John Doe 1', 30000, 1);

insert into employee (department_id, name, salary, id) 
values (2, 'John Doe 2', 30000, 2);


start transaction;

SELECT * 
FROM employee 
WHERE department_id = 1 
FOR UPDATE;


# new session

insert into employee (department_id, name, salary, id) 
values (3, 'Dave', 9000, 5)


  1. Hvordan kan jeg forespørge i mysql-table (hvor lat og long gemt) det, der er den nærmeste placering til den indtastede placering (lat og lang)?

  2. Udfør MySQL Stored Procedure ved hjælp af kommandolinjen

  3. Indlæs en csv-fil med specifikke kolonner ved hjælp af PDO

  4. mysql tjek sammenstilling af en tabel