mysql code to implement sequence function

mysql code to implement sequence function

MySQL implements sequence function

1. Create a sequence record table

CREATE TABLE `sys_sequence` (
 `seq_name` varchar(50) CHARACTER SET latin1 COLLATE latin1_bin NOT NULL,
 `min_value` int(11) NOT NULL,
 `max_value` int(11) NOT NULL,
 `current_value` int(11) NOT NULL,
 `increment_value` int(11) NOT NULL DEFAULT '1',
 PRIMARY KEY (`seq_name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

2. Establish sequence basic functions

DELIMITER $$
CREATE DEFINER=`root`@`%` FUNCTION `_nextval`(name varchar(50)) RETURNS int(11)
begin 
declare _cur int;
declare _maxvalue int; -- receive the maximum value declare _increment int; -- receive the number of increment steps set _increment = (select increment_value from sys_sequence where seq_name = name);
set _maxvalue = (select max_value from sys_sequence where seq_name = name);
set _cur = (select current_value from sys_sequence where seq_name = name); 
update sys_sequence -- Update the current value set current_value = _cur + increment_value 
where seq_name = name ; 
if(_cur + _increment >= _maxvalue) then -- Check if both have reached the maximum value update sys_sequence 
    set current_value = min_value 
    where seq_name = name ;
end if;
return _cur; 
end$$
DELIMITER ;

3. Insert the sequence you want to create

INSERT INTO `mydb`.`sys_sequence`
(`seq_name`,
`min_value`,
`max_value`,
`current_value`,
`increment_value`)
VALUES
('seq_name1', 1, 99999999, 1, 1);

4. Use sequence

select _nextval('seq_name1');

Summarize

The above is the full content of this article. I hope that the content of this article will have certain reference learning value for your study or work. Thank you for your support of 123WORDPRESS.COM. If you want to learn more about this, please check out the following links

You may also be interested in:
  • Sequence implementation method based on MySQL
  • Tutorial on creating a self-increasing sequence in MySQL
  • How to set the automatic growth sequence SEQUENCE in MySQL

<<:  Detailed explanation of the application of Docker underlying technology Namespace Cgroup

>>:  How to use JavaScript to determine several common browsers through userAgent

Recommend

Docker commands are implemented so that ordinary users can execute them

After installing docker, there will usually be a ...

Display special symbols in HTML (with special character correspondence table)

Problem Reproduction When using HTML for editing,...

Detailed explanation of how to use WeChat mini program map

This article example shares the specific implemen...

What are the advantages of using B+ tree index in MySQL?

Before understanding this problem, let's firs...

W3C Tutorial (3): W3C HTML Activities

HTML is a hybrid language used for publishing on ...

Detailed explanation of MySQL clustered index and non-clustered index

1. Clustered Index Table data is stored in the or...

How to add and delete unique indexes for fields in MySQL

1. Add PRIMARY KEY (primary key index) mysql>A...

Nginx rush purchase current limiting configuration implementation analysis

Due to business needs, there are often rush purch...

Common writing examples for MySQL and Oracle batch insert SQL

Table of contents For example: General writing: S...

How to avoid garbled characters when importing external files (js/vbs/css)

In the page, external files such as js, css, etc. ...

Several common methods for setting anchor positioning in HTML

There are several ways I know of to set anchor pos...

Share 5 helpful CSS selectors to enrich your CSS experience

With a lot of CSS experience as a web designer, we...