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学院为您提供精彩教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
