MySQL implements a solution similar to Oracle sequence

MySQL implements a solution similar to Oracle sequence

MySQL implements Oracle-like sequences

Oracle generally uses sequences to process primary key fields, while MySQL provides increment to achieve similar purposes.

However, in actual use, it is found that MySQL's auto-increment has many disadvantages: it is impossible to control the step size, start index, loop, etc.; if the database needs to be migrated, the primary key is also a big problem.

This article records a solution for simulating Oracle sequences, focusing on ideas and code secondarily.

The use of Oracle sequences is nothing more than using the .nextval and .currval pseudo columns. The basic idea is:

1. Create a new table in MySQL to store sequence names and values;

2. Create a function to get the value in the sequence table;

The details are as follows:

The table structure is:

drop table if exists sequence;  
create table sequence (  
  seq_name VARCHAR(50) NOT NULL, -- sequence name current_val INT NOT NULL, -- current value increment_val INT NOT NULL DEFAULT 1, -- step length (span)  
  PRIMARY KEY (seq_name)  
);

Implementing a simulation of currval

create function currval(v_seq_name VARCHAR(50))  
returns integer 
begin 
  declare value integer;  
  set value = 0;  
  select current_value into value  
  from sequence 
  where seq_name = v_seq_name;  
  return value;  
end;

Function usage: select currval('MovieSeq');

Implementing the simulation scheme of nextval

create function nextval (v_seq_name VARCHAR(50))  
return integer 
begin 
 update sequence 
 set current_val = current_val + increment_val  
 where seq_name = v_seq_name;  
 return currval(v_seq_name);  
end;

The function is used as: select nextval('MovieSeq');

Function that increases the value of a setting

create function setval(v_seq_name VARCHAR(50), v_new_val INTEGER)  
returns integer 
begin 
 update sequence 
 set current_val = v_new_val  
 where seq_name = v_seq_name;  
return currval(seq_name);

Similarly, functions for step size operations can be added, which will not be described here.

Pay attention to the syntax, the database fields should correspond to

use bvboms; 
DELIMITER $$ 
create function setval(v_seq_name VARCHAR(50), v_new_val INTEGER) 
returns integer 
begin 
 update sequence 
 set current_val = v_new_val 
 where seq_name = v_seq_name; 
return currval(seq_name);
end $$
DELIMITER $$

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:
  • Detailed explanation of the solution for real-time synchronization from MySQL to Oracle
  • Summary of commonly used multi-table modification statements in Mysql and Oracle
  • Summary of the differences between MySQL and Oracle (comparison of functional performance, selection, SQL when using them, etc.)
  • Import backup between mysql database and oracle database
  • The implementation process of extracting oracle data to mysql database
  • Comparative Analysis of High Availability Solutions of Oracle and MySQL
  • Comparison of the differences between MySQL and Oracle: six triggers
  • Comparison of the differences between MySQL and Oracle: Five: Stored Procedures & Functions
  • MySQL and Oracle differences comparison three functions
  • Detailed explanation of the misunderstanding between MySQL and Oracle

<<:  How to implement MySQL master-slave replication based on Docker

>>:  JavaScript to achieve simple tab bar switching case

Recommend

Simple setup of VMware ESXi6.7 (with pictures and text)

1. Introduction to VMware vSphere VMware vSphere ...

A brief discussion on four solutions for Vue single page SEO

Table of contents 1.Nuxt server-side rendering ap...

A brief discussion on MySQL large table optimization solution

background The amount of new data in the business...

How to forget the password of Jenkins in Linux

1.Jenkins installation steps: https://www.jb51.ne...

Detailed explanation of the construction and use of Docker private warehouse

The image can be saved on hub.docker.com, but the...

js to achieve interesting countdown effect

js interesting countdown case, for your reference...

Example of how to use CSS3 to layout elements around a center point

This article introduces an example of how CSS3 ca...

Linux system disk formatting and manually adding swap partition

Windows: Support NTFS, FAT Linux supports file fo...

What does href=# mean in a link?

Links to the current page. ------------------- Com...

CSS example code to hide the scroll bar and scroll the content

Preface When the HTML structure of a page contain...

How to upgrade all Python libraries in Ubuntu 18.04 at once

What is pip pip is a Python package management to...

Implementation of rewrite jump in nginx

1. New and old domain name jump Application scena...

How to configure virtual user login in vsftpd

yum install vsftpd [root@localhost etc]# yum -y i...

Solve the problem of installing Theano on Ubuntu 19

Solution: Directly in the directory where you dow...

Vue application example code based on axios request encapsulation

Table of contents What is axios? Axios request ty...