Mysql实例在MySQL中创建实现自增的序列(Sequence)的教程
《Mysql实例在MySQL中创建实现自增的序列(Sequence)的教程》要点: 项目应用中,曾有以下一个场景: 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; ? DROP FUNCTION IF EXISTS currval; DELIMITER $ CREATE FUNCTION currval (seq_name VARCHAR(50)) RETURNS INTEGER LANGUAGE SQL DETERMINISTIC CONTAINS SQL SQL SECURITY DEFINER COMMENT '' BEGIN DECLARE value INTEGER; SET value = 0; SELECT current_value INTO value FROM sequence WHERE name = seq_name; RETURN value; END $ DELIMITER ; ? DROP FUNCTION IF EXISTS nextval; DELIMITER $ CREATE FUNCTION nextval (seq_name VARCHAR(50)) RETURNS INTEGER LANGUAGE SQL DETERMINISTIC CONTAINS SQL SQL SECURITY DEFINER COMMENT '' BEGIN UPDATE sequence SET current_value = current_value + increment WHERE name = seq_name; RETURN currval(seq_name); END $ DELIMITER ; ? DROP FUNCTION IF EXISTS setval; DELIMITER $ CREATE FUNCTION setval (seq_name VARCHAR(50),value INTEGER) RETURNS INTEGER LANGUAGE SQL DETERMINISTIC CONTAINS SQL SQL SECURITY DEFINER COMMENT '' BEGIN UPDATE sequence SET current_value = value WHERE name = seq_name; RETURN currval(seq_name); END $ DELIMITER ; ?
?MYSQL应用 ? public void testGetSequence() { Connection conn = JDBCUtils.getConnection(url,userName,password); String sql = "SELECT CURRVAL('TestSeq');"; PreparedStatement ptmt = null; ResultSet rs = null; try { ptmt = conn.prepareStatement(sql); rs = ptmt.executeQuery(); int count = 0; while (rs.next()) { count = rs.getInt(1); } System.out.println(count); } catch (SQLException e) { e.printStackTrace(); } finally { JDBCUtils.close(rs,ptmt,conn); } } ? 在 oracle 中,sequence 提供多表多字段可共用一个不重复值. Mysql 中存在自增列,基本可以满足 PK 的要求.但自增列存在限制:MYSQL应用 a. 只能用于表中的一个字段,一张不能同时存在两个以上的自增列 ;MYSQL应用 b. 自增列必须被定义为 key ( PK 或 FK ) ;MYSQL应用 c. 自增列不能被多个表共用 ;MYSQL应用 d. 当 insert 语句不包括自增字段或将其值设置为 NULL 时,该值会自动填上.MYSQL应用 在不要求字段顺序递增的情况下,可以在 Mysql 中实现序列,再来看下面一个例子: DROP TABLE IF EXISTS sequence; -- 建sequence表,指定seq列为无符号大整型,可支持无符号值:0(default)到18446744073709551615(0到2^64C1). CREATE TABLE sequence ( name VARCHAR(50) NOT NULL,current_value BIGINT UNSIGNED NOT NULL DEFAULT 0,increment INT NOT NULL DEFAULT 1,PRIMARY KEY (name) -- 不允许重复seq的存在. ) ENGINE=InnoDB; DELIMITER / DROP FUNCTION IF EXISTS currval / CREATE FUNCTION currval(seq_name VARCHAR(50)) RETURNS BIGINT BEGIN DECLARE value BIGINT; SELECT current_value INTO value FROM sequence WHERE upper(name) = upper(seq_name); -- 大小写不区分. RETURN value; END; / DELIMITER ; DELIMITER / DROP FUNCTION IF EXISTS nextval / CREATE FUNCTION nextval (seq_name VARCHAR(50)) RETURNS BIGINT BEGIN DECLARE value BIGINT; UPDATE sequence SET current_value = current_value + increment WHERE upper(name) = upper(seq_name); RETURN currval(seq_name); END; / DELIMITER ; DELIMITER / DROP FUNCTION IF EXISTS setval / CREATE FUNCTION setval (seq_name VARCHAR(50),value BIGINT) RETURNS BIGINT BEGIN UPDATE sequence SET current_value = value WHERE upper(name) = upper(seq_name); RETURN currval(seq_name); END; / DELIMITER ; ?在 SQL 中使用序列: mysql> insert into sequence set name='myseq'; 查看当前已建序列: mysql> select * from sequence; +-------+---------------+-----------+ | name | current_value | increment | +-------+---------------+-----------+ | myseq | 0 | 1 | +-------+---------------+-----------+ 1 row in set (0.00 sec) 获得序列的下一个值,第一次使用,因此值为1: mysql> select nextval('myseq'); +------------------+ | nextval('myseq') | +------------------+ | 1 | +------------------+ 1 row in set (0.00 sec) 《Mysql实例在MySQL中创建实现自增的序列(Sequence)的教程》是否对您有启发,欢迎查看更多与《Mysql实例在MySQL中创建实现自增的序列(Sequence)的教程》相关教程,学精学透。编程之家PHP学院为您提供精彩教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |