设为首页 加入收藏

TOP

MySQL序列解决方案(二)
2014-11-23 23:37:30 来源: 作者: 【 】 浏览:22
Tags:MySQL 序列 解决方案
----------+
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

Java代码

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 ;

Java代码

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

setval

Java代码

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 ;

Java代码

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

作者“ERDP技术架构”

首页 上一页 1 2 下一页 尾页 2/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇用distinct在MySQL中查询多条不重.. 下一篇MySQL数据库索引查询优化的分享

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: