Rumah pangkalan data tutorial mysql MySQL实现类似Oracle的序列_MySQL

MySQL实现类似Oracle的序列_MySQL

Jun 01, 2016 pm 01:28 PM
oracle

bitsCN.com

MySQL实现类似Oracle的序列

 

Oracle一般使用序列(Sequence)来处理主键字段,而MySQL则提供了自增长(increment)来实现类似的目的;

但在实际使用过程中发现,MySQL的自增长有诸多的弊端:不能控制步长、开始索引、是否循环等;若需要迁移数据库,则对于主键这块,也是个头大的问题。

本文记录了一个模拟Oracle序列的方案,重点是想法,代码其次。

Oracle序列的使用,无非是使用.nextval和.currval伪列,基本想法是:1、MySQL中新建表,用于存储序列名称和值;2、创建函数,用于获取序列表中的值;

具体如下:

表结构为

 

 

[sql] 

表结构为:  

drop table if exists sequence;  create table sequence (      seq_name        VARCHAR(50) NOT NULL, -- 序列名称      current_val     INT         NOT NULL, --当前值      increment_val   INT         NOT NULL    DEFAULT 1, --步长(跨度)      PRIMARY KEY (seq_name)  );  
Salin selepas log masuk

实现currval的模拟方案

[sql] 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;  
Salin selepas log masuk

[sql]

函数使用为:select currval('MovieSeq');

实现nextval的模拟方案

[sql] 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;  
Salin selepas log masuk

[sql]

函数使用为:select nextval('MovieSeq');

增加设置值的函数

[sql] 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);  
Salin selepas log masuk

 

 

同理,可以增加对步长操作的函数,在此不再叙述。

bitsCN.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Berfungsi untuk mengira bilangan hari antara dua tarikh dalam oracle Berfungsi untuk mengira bilangan hari antara dua tarikh dalam oracle May 08, 2024 pm 07:45 PM

Berfungsi untuk mengira bilangan hari antara dua tarikh dalam oracle

Berapa lama log pangkalan data Oracle akan disimpan? Berapa lama log pangkalan data Oracle akan disimpan? May 10, 2024 am 03:27 AM

Berapa lama log pangkalan data Oracle akan disimpan?

Urutan langkah permulaan pangkalan data oracle ialah Urutan langkah permulaan pangkalan data oracle ialah May 10, 2024 am 01:48 AM

Urutan langkah permulaan pangkalan data oracle ialah

Cara menggunakan selang dalam oracle Cara menggunakan selang dalam oracle May 08, 2024 pm 07:54 PM

Cara menggunakan selang dalam oracle

Bagaimana untuk melihat bilangan kemunculan watak tertentu dalam Oracle Bagaimana untuk melihat bilangan kemunculan watak tertentu dalam Oracle May 09, 2024 pm 09:33 PM

Bagaimana untuk melihat bilangan kemunculan watak tertentu dalam Oracle

Bagaimana untuk menentukan sama ada dua rentetan terkandung dalam oracle Bagaimana untuk menentukan sama ada dua rentetan terkandung dalam oracle May 08, 2024 pm 07:00 PM

Bagaimana untuk menentukan sama ada dua rentetan terkandung dalam oracle

Keperluan konfigurasi perkakasan pelayan pangkalan data Oracle Keperluan konfigurasi perkakasan pelayan pangkalan data Oracle May 10, 2024 am 04:00 AM

Keperluan konfigurasi perkakasan pelayan pangkalan data Oracle

Berapa banyak memori yang diperlukan oleh oracle? Berapa banyak memori yang diperlukan oleh oracle? May 10, 2024 am 04:12 AM

Berapa banyak memori yang diperlukan oleh oracle?

See all articles