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. CSS水平垂直居中常见方法总结

    1.元素水平居中 当然最好使的是: margin: 0 auto; 居中不好使的原因: 1.元素没有设置宽度,没有宽度怎么居中嘛! 2.设置了宽度依然不好使,你设置的是行内元素吧,行内元素和块元素的区 ...

  2. 【转】centos升级curl版本

    1.安装repo rpm -Uvh http://www.city-fan.org/ftp/contrib/yum-repo/rhel6/x86_64/city-fan.org-release-2-1 ...

  3. if条件语句!

    1.if 单分支语句 if [ 条件语句 ]  then 条件操作fi 例子: [root@localhost ~]# if [ 1 -eq 0 ]                    //如果1等 ...

  4. 操作系统OS - 常见系统的调度算法

    https://en.wikipedia.org/wiki/Scheduling_(computing) 在wiki的下面可以找到

  5. updataxml报错注入

    // take the variables//接受变量 // //也就是插入post提交的uname和passwd,参见:https://www.w3school.com.cn/sql/sql_ins ...

  6. 去重sort|uniq -d

    #!/bin/bash ############################################################### #Author :Bing # #Create ...

  7. windows下 DEV-C++无法连接到pthread.h的解决办法

    参考的这个博文,原博文有图片:http://lslin.iteye.com/blog/776325 (我只是为了方便写.copy一遍) dev-C++编写C/C++程序时,非常方便轻巧,但是今天学习多 ...

  8. c++中的运算符重载operator1(翁恺c++公开课[30]学习笔记)

    运算符重载规则: 只有已经存在的运算符才能被重载,不能自己制造一个c++中没有的运算符进行重载 重载可以在类或枚举类型内进行,也可以是全局函数,但int.float这种已有的类型内是不被允许的 不能二 ...

  9. 高版本的Hibernate

    我的查询语句是“from TA pojo where pojo.tbs.name='tb1'”,可结果报错. 高版本的Hibernate不能这样查Set了, 要改成这样: from TA pojo i ...

  10. linux命令系列-mv(移动-重命名)

    #常用命令选项 默认覆盖 -n 不覆盖 -i 交互 -f 不交互直接覆盖 -u 只移动新的文件 -v 显示详细信息 #移动覆盖3个文件到/tmp目录 mv a.txt b.txt c.txt /tmp ...