时间:2021-07-01 10:21:17 帮助过:8人阅读
MySQL实现序列效果
一般使用序列(Sequence)来处理主键字段,在MySQL中是没有序列的,但是MySQL有提供了自增长(increment)来实现类似的目的,但也只是自增,而不能设置步长、开始索引、是否循环等,最重要的是一张表只能由一个字段使用自增,但有的时候我们需要两个或两个以上的字段实现自增(单表多字段自增),MySQL本身是实现不了的,但我们可以用创建一个序列表,使用函数来获取序列的值。
1. 新建序列表
drop
table
if exists
sequence
;
create
table
sequence
(
seq_name
VARCHAR
(50)
NOT
NULL
,
-- 序列名称
current_val
INT
NOT
NULL
,
-- 当前值
increment_val
INT
NOT
NULL
DEFAULT
1,
-- 步长(跨度)
PRIMARY
KEY
(seq_name) );
2. 新增一个序列
INSERT
INTO
sequence
VALUES
(
‘seq_test1_num1‘
,
‘0‘
,
‘1‘
);
INSERT
INTO
sequence
VALUES
(
‘seq_test1_num2‘
,
‘0‘
,
‘2‘
);
3. 创建 函数 用于获取序列当前值(v_seq_name 参数值 代表序列名称)
create
function
currval(v_seq_name
VARCHAR
(50))
returns
integer
begin
declare
value
integer
;
set
value = 0;
select
current_val
into
value
from
sequence
where
seq_name = v_seq_name;
return
value;
end
;
4. 查询当前值
select
currval(
‘seq_test1_num1‘
);
5. 创建 函数 用于获取序列下一个值(v_seq_name 参数值 代表序列名称)
create
function
nextval (v_seq_name
VARCHAR
(50))
returns
integer
begin
update
sequence
set
current_val = current_val + increment_val
where
seq_name = v_seq_name;
return
currval(v_seq_name);
end
;
6. 查询下一个值
select
nextval(
‘seq_test1_num1‘
);
7. 新建表 用于测试的表
DROP
TABLE
IF EXISTS `test1`;
CREATE
TABLE
`test1` (
`
name
`
varchar
(255)
NOT
NULL
,
`value`
double
(255,0)
DEFAULT
NULL
,
`num1`
int
(11)
DEFAULT
NULL
,
`num2`
int
(11)
DEFAULT
NULL
,
PRIMARY
KEY
(`
name
`)
);
8. 新建触发器 插入新纪录前给自增字段赋值实现字段自增效果
CREATE
TRIGGER
`TRI_test1_num1` BEFORE
INSERT
ON
`test1`
FOR
EACH ROW
BEGIN
set
NEW.num1 = nextval(
‘seq_test1_num1‘
);
set
NEW.num2 = nextval(
‘seq_test1_num2‘
);
END
9. 最后测试自增效果
INSERT
INTO
test1 (
name
, value)
VALUES
(
‘1‘
,
‘111‘
);
INSERT
INTO
test1 (
name
, value)
VALUES
(
‘2‘
,
‘222‘
);
INSERT
INTO
test1 (
name
, value)
VALUES
(
‘3‘
,
‘333‘
);
INSERT
INTO
test1 (
name
, value)
VALUES
(
‘4‘
,
‘444‘
);
10. 结果展示
SELECT
*
FROM
test1;
转载自https://www.2cto.com/database/201508/427101.html
MySQL实现序列(Sequence)效果
标签:create .com from select declare currval 测试 string func