MySQL自增长与Oracle序列的区别:
自增长只能用于表中的其中一个字段
自增长只能被分配给固定表的固定的某一字段,不能被多个表共用.
自增长会把一个未指定或NULL值的字段自动填上.

在mysql中添加序列,请看下面的实例:
在MYSQL里有这样一张表:

  1. CREATE TABLE Movie(
  2. id           INT NOT NULL AUTO_INCREMENT,
  3. name     VARCHAR(60) NOT NULL,
  4. released YEAR NOT NULL,
  5. PRIMARY KEY (id)
  6. ) ENGINE=InnoDB;

CREATE TABLE Movie(
id INT NOT NULL AUTO_INCREMENT,
name VARCHAR(60) NOT NULL,
released YEAR NOT NULL,
PRIMARY KEY (id)
) ENGINE=InnoDB;

  1. INSERT INTO Movie (name,released) VALUES ('Gladiator',2000);
  2. INSERT INTO Movie (id,name,released) VALUES (NULL,'The Bourne Identity',1998);

INSERT INTO Movie (name,released) VALUES ('Gladiator',2000);
INSERT INTO Movie (id,name,released) VALUES (NULL,'The Bourne Identity',1998);

在ORACLE是这样的:

  1. CREATE TABLE Movie(
  2. id          INT NOT NULL,
  3. name     VARCHAR2(60) NOT NULL,
  4. released INT NOT NULL,
  5. PRIMARY KEY (id)
  6. );
  7. CREATE SEQUENCE MovieSeq;

CREATE TABLE Movie(
id INT NOT NULL,
name VARCHAR2(60) NOT NULL,
released INT NOT NULL,
PRIMARY KEY (id)
);
CREATE SEQUENCE MovieSeq;

  1. INSERT INTO Movie (id,name,released) VALUES (MovieSeq.NEXTVAL,'Gladiator',2000);

INSERT INTO Movie (id,name,released) VALUES (MovieSeq.NEXTVAL,'Gladiator',2000);

在oracle下为表添加一个触发器,就可以实现mysql自增长功能:

  1. CREATE OR REPLACE TRIGGER BRI_MOVIE_TRG
  2. BEFORE INSERT ON Movie
  3. FOR EACH ROW
  4. BEGIN
  5. SELECT MovieSeq.NEXTVAL INTO :new.id FROM DUAL;
  6. END BRI_MOVIE_TRG;
  7. .
  8. RUN;

CREATE OR REPLACE TRIGGER BRI_MOVIE_TRG
BEFORE INSERT ON Movie
FOR EACH ROW
BEGIN
SELECT MovieSeq.NEXTVAL INTO :new.id FROM DUAL;
END BRI_MOVIE_TRG;
.
RUN;

这样,插件记录就可以成为MYSQL风格:

  1. INSERT INTO Movie (name,released) VALUES ('The Lion King',1994);

INSERT INTO Movie (name,released) VALUES ('The Lion King',1994);

下面我们来看看如何在mysql数据里使用Oracle序列语法.NEXTVAL 和 .CURVAL.
我们假设在mysql中序列的语法是:

NEXTVAL(’sequence’);
CURRVAL(’sequence’);
SETVAL(’sequence’,value);

下面就是CURRRVAL的实现方案:

  1. DROP TABLE IF EXISTS sequence;
  2. CREATE TABLE sequence (
  3. name              VARCHAR(50) NOT NULL,
  4. current_value INT NOT NULL,
  5. increment       INT NOT NULL DEFAULT 1,
  6. PRIMARY KEY (name)
  7. ) ENGINE=InnoDB;
  8. INSERT INTO sequence VALUES ('MovieSeq',3,5);
  9. DROP FUNCTION IF EXISTS currval;
  10. DELIMITER $
  11. CREATE FUNCTION currval (seq_name VARCHAR(50))
  12. RETURNS INTEGER
  13. CONTAINS SQL
  14. BEGIN
  15. DECLARE value INTEGER;
  16. SET value = 0;
  17. SELECT current_value INTO value
  18. FROM sequence
  19. WHERE name = seq_name;
  20. RETURN value;
  21. END$
  22. DELIMITER ;

DROP TABLE IF EXISTS sequence;
CREATE TABLE sequence (
name VARCHAR(50) NOT NULL,
current_value INT NOT NULL,
increment INT NOT NULL DEFAULT 1,
PRIMARY KEY (name)
) ENGINE=InnoDB;
INSERT INTO sequence VALUES ('MovieSeq',3,5);
DROP FUNCTION IF EXISTS currval;
DELIMITER $
CREATE FUNCTION currval (seq_name VARCHAR(50))
RETURNS INTEGER
CONTAINS SQL
BEGIN
DECLARE value INTEGER;
SET value = 0;
SELECT current_value INTO value
FROM sequence
WHERE name = seq_name;
RETURN value;
END$
DELIMITER ;

测试一下结果:

  1. mysql> SELECT currval('MovieSeq');
  2. +---------------------+
  3. | currval('MovieSeq') |
  4. +---------------------+
  5. |                   3 |
  6. +---------------------+
  7. 1 row in set (0.00 sec)
  8. mysql> SELECT currval('x');
  9. +--------------+
  10. | currval('x') |
  11. +--------------+
  12. |            0 |
  13. +--------------+
  14. 1 row in set, 1 warning (0.00 sec)
  15. mysql> show warnings;
  16. +---------+------+------------------+
  17. | Level   | Code | Message          |
  18. +---------+------+------------------+
  19. | Warning | 1329 | No data to FETCH |
  20. +---------+------+------------------+
  21. 1 row in set (0.00 sec)

mysql> SELECT currval('MovieSeq');
+---------------------+
| currval('MovieSeq') |
+---------------------+
| 3 |
+---------------------+
1 row in set (0.00 sec)
mysql> SELECT currval('x');
+--------------+
| currval('x') |
+--------------+
| 0 |
+--------------+
1 row in set, 1 warning (0.00 sec)
mysql> show warnings;
+---------+------+------------------+
| Level | Code | Message |
+---------+------+------------------+
| Warning | 1329 | No data to FETCH |
+---------+------+------------------+
1 row in set (0.00 sec)

nextval

  1. DROP FUNCTION IF EXISTS nextval;
  2. DELIMITER $
  3. CREATE FUNCTION nextval (seq_name VARCHAR(50))
  4. RETURNS INTEGER
  5. CONTAINS SQL
  6. BEGIN
  7. UPDATE sequence
  8. SET          current_value = current_value + increment
  9. WHERE name = seq_name;
  10. RETURN currval(seq_name);
  11. END$
  12. DELIMITER ;

DROP FUNCTION IF EXISTS nextval;
DELIMITER $
CREATE FUNCTION nextval (seq_name VARCHAR(50))
RETURNS INTEGER
CONTAINS SQL
BEGIN
UPDATE sequence
SET current_value = current_value + increment
WHERE name = seq_name;
RETURN currval(seq_name);
END$
DELIMITER ;

  1. mysql> select nextval('MovieSeq');
  2. +---------------------+
  3. | nextval('MovieSeq') |
  4. +---------------------+
  5. |                  15 |
  6. +---------------------+
  7. 1 row in set (0.09 sec)
  8. mysql> select nextval('MovieSeq');
  9. +---------------------+
  10. | nextval('MovieSeq') |
  11. +---------------------+
  12. |                  20 |
  13. +---------------------+
  14. 1 row in set (0.01 sec)
  15. mysql> select nextval('MovieSeq');
  16. +---------------------+
  17. | nextval('MovieSeq') |
  18. +---------------------+
  19. |                  25 |
  20. +---------------------+
  21. 1 row in set (0.00 sec)

mysql> select nextval('MovieSeq');
+---------------------+
| nextval('MovieSeq') |
+---------------------+
| 15 |
+---------------------+
1 row in set (0.09 sec)

mysql> select nextval('MovieSeq');
+---------------------+
| nextval('MovieSeq') |
+---------------------+
| 20 |
+---------------------+
1 row in set (0.01 sec)

mysql> select nextval('MovieSeq');
+---------------------+
| nextval('MovieSeq') |
+---------------------+
| 25 |
+---------------------+
1 row in set (0.00 sec)

setval

  1. DROP FUNCTION IF EXISTS setval;
  2. DELIMITER $
  3. CREATE FUNCTION setval (seq_name VARCHAR(50), value INTEGER)
  4. RETURNS INTEGER
  5. CONTAINS SQL
  6. BEGIN
  7. UPDATE sequence
  8. SET          current_value = value
  9. WHERE name = seq_name;
  10. RETURN currval(seq_name);
  11. END$
  12. DELIMITER ;

DROP FUNCTION IF EXISTS setval;
DELIMITER $
CREATE FUNCTION setval (seq_name VARCHAR(50), value INTEGER)
RETURNS INTEGER
CONTAINS SQL
BEGIN
UPDATE sequence
SET current_value = value
WHERE name = seq_name;
RETURN currval(seq_name);
END$
DELIMITER ;

  1. mysql> select setval('MovieSeq',150);
  2. +------------------------+
  3. | setval('MovieSeq',150) |
  4. +------------------------+
  5. |                    150 |
  6. +------------------------+
  7. 1 row in set (0.06 sec)
  8. mysql> select curval('MovieSeq');
  9. +---------------------+
  10. | currval('MovieSeq') |
  11. +---------------------+
  12. |                 150 |
  13. +---------------------+
  14. 1 row in set (0.00 sec)
  15. mysql> select nextval('MovieSeq');
  16. +---------------------+
  17. | nextval('MovieSeq') |
  18. +---------------------+
  19. |                 155 |
  20. +---------------------+
  21. 1 row in set (0.00 sec)

mysql> select setval('MovieSeq',150);
+------------------------+
| setval('MovieSeq',150) |
+------------------------+
| 150 |
+------------------------+
1 row in set (0.06 sec)

mysql> select curval('MovieSeq');
+---------------------+
| currval('MovieSeq') |
+---------------------+
| 150 |
+---------------------+
1 row in set (0.00 sec)

mysql> select nextval('MovieSeq');
+---------------------+
| nextval('MovieSeq') |
+---------------------+
| 155 |
+---------------------+
1 row in set (0.00 sec)

分享到:

参考知识库
MySQL知识库

20189  关注 | 1446  收录

评论

MySQL序列解决方案的更多相关文章

  1. mysql 序列与pg序列的比较

    mysql序列(这里只谈innodb引擎): 在使用mysql的AUTO_INCREMENT时,使用AUTO_INCREMENT的字段必须建有索引,也可以为索引的一部分.当没有索引时会报错:      ...

  2. 远程无法连接Mysql 的解决方案

    问题描述: 新安装了MySQL 5.6,使用root用户无法远程连接, 提示Host 'xxx.xxx.xxx.xxx' is not allowed to connect to this MySQL ...

  3. MySQL 序列使用

    MySQL 序列使用 MySQL序列是一组整数:1, 2, 3, ...,由于一张数据表只能有一个字段自增主键, 如果你想实现其他字段也实现自动增加,就可以使用MySQL序列来实现. 本章我们将介绍如 ...

  4. 【已解决】Windows下 MySQL大小写敏感 解决方案及分析

    Windows下 MySQL大小写敏感配置 zoerywzhou@163.com http://www.cnblogs.com/swje/ 作者:Zhouwan 2017-3-27 最近在window ...

  5. MySQL 序列 AUTO_INCREMENT

    MySQL序列是一组整数:1, 2, 3, ...,由于一张数据表只能有一个字段自增主键, 如果你想实现其他字段也实现自动增加,就可以使用MySQL序列来实现. 本章我们将介绍如何使用MySQL的序列 ...

  6. 二十九、MySQL 序列使用

    MySQL 序列使用 MySQL 序列是一组整数:1, 2, 3, ...,由于一张数据表只能有一个字段自增主键, 如果你想实现其他字段也实现自动增加,就可以使用MySQL序列来实现. 本章我们将介绍 ...

  7. DB-MySQL:MySQL 序列使用

    ylbtech-DB-MySQL:MySQL 序列使用 1.返回顶部 1. MySQL 序列使用 MySQL 序列是一组整数:1, 2, 3, ...,由于一张数据表只能有一个字段自增主键, 如果你想 ...

  8. 吴裕雄--天生自然MySQL学习笔记:MySQL 序列使用

    MySQL 序列是一组整数:1, 2, 3, ...,由于一张数据表只能有一个字段自增主键, 如果你想实现其他字段也实现自动增加,就可以使用MySQL序列来实现. 使用 AUTO_INCREMENT ...

  9. mysql error 1130 hy000:Host 'localhost' is not allowed to connect to this mysql server 解决方案

    ERROR 1130 (HY000): Host 'localhost' is not allowed to connect to this MySQL server D:\Wamp\mysql-\b ...

随机推荐

  1. windows下的环境搭建配置redis

    http://blog.csdn.net/spring21st/article/details/11176723

  2. 【PAT甲级】1039 Course List for Student (25 分)(vector嵌套于map,段错误原因未知)

    题意: 输入两个正整数N和K(N<=40000,K<=2500),分别为学生和课程的数量.接下来输入K门课的信息,先输入每门课的ID再输入有多少学生选了这门课,接下来输入学生们的ID.最后 ...

  3. 利用 Jenkins 持续集成 iOS 项目,搭建自动化打包环境

    ---恢复内容开始--- jenkins是一个广泛用于持续构建的可视化web工具,持续构建即各种项目的”自动化”编译.打包.分发部署.jenkins可以很好的支持各种语言(比如:Java, c#, P ...

  4. MBR扇区故障修复!

    一:进行分区且格式化硬盘 [root@roomc~]#mkfs -t ext4 /dev/sdb1    //格式化sdb1盘 二:模拟破坏/sda主硬盘破坏再修复! [root@roomc~]#mk ...

  5. #P2010 回文日期 的题解

    题目描述 在日常生活中,通过年.月.日这三个要素可以表示出一个唯一确定的日期. 牛牛习惯用88位数字表示一个日期,其中,前44位代表年份,接下来22位代表月 份,最后22位代表日期.显然:一个日期只有 ...

  6. 第七届蓝桥杯javaB组真题解析-方格填数(第六题)

    题目 /* 方格填数 如下的10个格子 +--+--+--+ | | | | +--+--+--+--+ | | | | | +--+--+--+--+ | | | | +--+--+--+ (如果显 ...

  7. Vulnhub_DC1 记录

    目录 Vulnhub_DC1 记录 经验 & 总结 步骤流水 1. 建立立足点 2. 提权 3. 主机信息搜集 4. 继续提权 5. 消失的flag Vulnhub_DC1 记录 参考walk ...

  8. Python环境搭建-4 pip的安装和使用

    pip的安装和使用 我们都知道python有很多的第三方库或者说是模块.这些库针对不同的应用,发挥不同的作用.我们在实际的项目中肯定会用到这些模块.那如何将这些模块导入到自己的项目中呢? Python ...

  9. python学习 —— 字符画

    代码: import os from PIL import Image WIDTH = int(250) HEIGHT = int(250/2) ascii_char = list('toahkbdp ...

  10. js中的arguments、Array.prototype.slice.call()

    类数组对象:arguments js把传入到这个函数的全部参数存储在arguments里面,其实arguments也是个对象,而且是一个特殊的对象,它的属性名是按照传入参数的序列来的,第1个参数的属性 ...