summaryrefslogtreecommitdiff
path: root/mysql-test/suite/sql_sequence/next.test
blob: a1f91bd7823d2a4dee7c2e7ad821e89a69f1101d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
--source include/have_sequence.inc
--source include/have_innodb.inc

#
# Test sequence generation
#

CREATE SEQUENCE t1 start with 1 minvalue 1 maxvalue 10 increment by 1 cache 2 cycle;
show create table t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;

select NEXT VALUE for t1,seq from seq_1_to_20;

drop sequence t1;

CREATE SEQUENCE t1 minvalue 1 maxvalue 10 increment by -1 cache 2 cycle engine=aria;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;
select next value for t1;
select next_not_cached_value,cycle_count from t1;

select NEXT VALUE for t1,seq from seq_1_to_20;

drop sequence t1;

CREATE SEQUENCE t1 start with 8 minvalue 1 maxvalue 10 increment by 1 cache 2 nocycle;
select next value for t1;
select next value for t1;
select next value for t1;
select previous value for t1;
--error ER_SEQUENCE_RUN_OUT
select next value for t1;
select previous value for t1;
--error ER_SEQUENCE_RUN_OUT
select next value for t1;
drop sequence t1;

create sequence s1 start with 1 cache 2 maxvalue 5;
select next value for s1;
select next value for s1;
select next value for s1;
select next value for s1;
select next value for s1;
--error ER_SEQUENCE_RUN_OUT
select next value for s1;
drop sequence s1;

#
# Test that flush tables jumps to next next_not_cached_value
#

CREATE SEQUENCE t1 start with 1 minvalue 1 maxvalue 100 increment by 1 cache 10;
select next value for t1;
select * from t1;
flush tables;
select next value for t1;
select nextval(t1);
drop sequence t1;

#
# Test currval/previous
#

CREATE SEQUENCE t9 start with 1 minvalue 1 maxvalue 10 increment by 1 cache 5 cycle;
select previous value for t9;
select next value for t9;
select previous value for t9, lastval(t9);
select next value for t9;
select previous value for t9, lastval(t9);
select seq, previous value for t9, NEXT VALUE for t9, previous value for t9 from seq_1_to_20;
select * from t9;
drop sequence t9;

#
# CACHE = 0 should be same as CACHE = 1
#
CREATE SEQUENCE s1 cache=0;
select * from s1;
select next value for s1;
select next_not_cached_value from s1;
select next value for s1;
select next_not_cached_value from s1;
DROP SEQUENCE s1;
CREATE SEQUENCE s1 cache=1;
select next_not_cached_value from s1;
select next value for s1;
select next_not_cached_value from s1;
select next value for s1;
select next_not_cached_value from s1;
DROP SEQUENCE s1;
CREATE SEQUENCE s1 cache=2;
select next_not_cached_value from s1;
select next value for s1;
select next_not_cached_value from s1;
select next value for s1;
select next_not_cached_value from s1;
DROP SEQUENCE s1;

#
# Negative increment for sequence
#

CREATE SEQUENCE s1;
select next value for s1;
select next value for s1;
select next value for s1;
select next value for s1;
alter sequence s1 increment -2;
select * from s1;
select next value for s1;
select next value for s1;
alter sequence s1 restart 6;
select next value for s1;
select next value for s1;
select next value for s1;
--error ER_SEQUENCE_RUN_OUT
select next value for s1;
DROP SEQUENCE s1;

#
# Check what happens when one refers to a sequence that has been closed/deleted
#

CREATE SEQUENCE t1 start with 1 minvalue 1 maxvalue 10 increment by 1 cache 5 cycle;
select next value for t1;
select previous value for t1;
flush tables;
select previous value for t1;
drop sequence t1;
--error ER_NO_SUCH_TABLE
select previous value for t1;
CREATE SEQUENCE t1 start with 5 minvalue 1 maxvalue 10 increment by 1 cache 5 cycle;
select previous value for t1;
select next value for t1;
select previous value for t1;
drop sequence t1;

# This failed in an early build

CREATE or replace SEQUENCE  s1  MINVALUE 1 MAXVALUE 9999999999
INCREMENT BY 1 START WITH 3984356 CACHE 20 CYCLE engine=innodb;
show create table s1;
select * from s1;
select NEXT VALUE FOR s1;
select NEXT VALUE FOR s1;
select NEXT VALUE FOR s1;
select * from s1;
FLUSH TABLES;
select * from s1;
select NEXT VALUE FOR s1;
select * from s1;
drop sequence s1;

#
# Explain
#

CREATE SEQUENCE t1 start with 5 minvalue 1 maxvalue 10 increment by 1 cache 5 cycle;
explain select next value for t1;
explain select next value for t1, minimum_value from t1;
drop table t1;

#
# Using insert with NEXT VALUE
#

CREATE SEQUENCE s1;
CREATE TABLE t1 (a int);
insert into t1 values (next value for s1);
insert into t1 values (next value for s1);
select * from t1;
drop table t1,s1;

#
# Using update with NEXT VALUE
#

CREATE SEQUENCE s1;
CREATE TABLE t1 (a int primary key auto_increment, b int default 0) engine=myisam;
insert into t1 values (),(),(),(),(),(),();
update t1 set b= next value for s1 where a <= 3;
select * from t1;
drop table t1,s1;

#
# NO CACHE and InnoDB
#

CREATE OR REPLACE SEQUENCE s1 MINVALUE 1 MAXVALUE 9999999999 INCREMENT BY 1 START WITH 3984356 nocache CYCLE engine='innodb';
select * from s1;
select next value for s1;
explain extended select next value for s1;
explain extended select previous value for s1;
drop sequence s1;

#
# Some error testing
#

create table t1 (a int);
--error ER_NOT_SEQUENCE
select next value for t1;
drop table t1;

create sequence t1;
select next value for t1;
--error ER_BAD_FIELD_ERROR
select next value for t1, minimum_value;
drop sequence t1;

--echo #
--echo # MDEV-12854 Synchronize CREATE..SELECT data type and result set metadata data type for INT functions
--echo #

--enable_metadata
--disable_ps_protocol
CREATE SEQUENCE s1;
SELECT
  NEXT VALUE FOR s1,
  PREVIOUS VALUE FOR s1;
DROP SEQUENCE s1;
--enable_ps_protocol
--disable_metadata

--echo #
--echo # MDEV-13720 ER_NOT_SEQUENCE for temporary table
--echo #

create temporary table tmp (i int);
--error ER_NOT_SEQUENCE
select next value for tmp;
drop table tmp;

--echo #
--echo # Test negative numbers
--echo #

create sequence s start with 1 minvalue=-1000 maxvalue=1000 increment -1;
select next value for s;
select next value for s;
flush tables;
select next value for s;
drop sequence s;