Example of auto-increment ID for concurrent Security using mysql Transaction Features

Source: Internet
Author: User

Auto-increment IDs are often used in projects, such as uid. The simplest method is to directly use the AUTO_INCREMENT provided by the database. However, if the number of users is large, tens of millions, when hundreds of millions of users need to store sub-tables, this solution cannot be implemented, so it is best to have a global auto-incremental ID generator, whether or not it is a sub-table, global Auto-increment IDS can be obtained from the generator.

There should be many implementation methods, but all solutions need to solve one problem, that is, to ensure that the data is still obtained correctly in high concurrency scenarios, and the IDS obtained each time will not be repeated.

Here I will share two solutions that are implemented using the innodb Transaction Features of mysql. One is implemented, and the other is not tested, but it should also be accessible.

First, we will introduce the first method. In the database, we will set a separate table to store the ID. The table has two fields: one is the type, and the other is the ID:
Copy codeThe Code is as follows:
Create table auto_id (
Idname varchar (20) not null default '',
Id bigint (20) not null default 0 COMMENT '',
Primary key (idname)
) ENGINE = Innodb default charset = utf8;

Next is a stored procedure:
Copy codeThe Code is as follows:
Delimiter //
Drop procedure if exists get_increment_id;
Create procedure get_increment_id (in idname_in varchar (20), in small_in bigint, out id_out bigint)
Begin
Declare oldid bigint;
Start transaction;
Select id into oldid from maibo_auto_id where idname = idname_in for update;
If oldid is NULL then
Insert into maibo_auto_id (idname, id) value (idname_in, small_in );
Set id_out = small_in;
Else
Update maibo_auto_id set id = id + 1 where idname = idname_in;
Set id_out = oldid + 1;
End if;
Commit;
End;
//

The point is that select id into oldid from maibo_auto_id where idname = idname_in for update adds an exclusive lock to the relevant data. If other processes read this record, wait until the process is committed. This ensures that different processes do not get the same value in the case of concurrency.

If your front-end is implemented using php.

You only need to execute the following two SQL statements to get the result. The small parameter defines the auto-increment starting from the number.
Copy codeThe Code is as follows:
$ SQL = "call get_increment_id ('{$ key}', {$ small}, @ id )";
$ Ret = $ db-> getData ("select @ id ");


Another method is to use mysql auto_increment.

Create a table with only one auto-increment field in it:
Copy codeThe Code is as follows:
Create table test (
'Id' int (11) not null AUTO_INCREMENT COMMENT 'id ',
Primary key (id)
) ENGINE = MyISAM AUTO_INCREMENT = 1 default charset = utf8;

Use the following two SQL statements:
Copy codeThe Code is as follows:
UPDATE test SET id = LAST_INSERT_ID (id + 1 );
SELECT LAST_INSERT_ID ();

The problem can also be solved. LAST_INSERT_ID does not need to be queried and only applies to the current connection. That is to say, the update of other connections does not affect the value of the current connection.

In this way, each ID may have to get a table for maintenance, which is also a disadvantage.

How to deal with it in use depends on your choice.

Related Article

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.