mirror of
https://github.com/MariaDB/server.git
synced 2025-01-17 20:42:30 +01:00
214 lines
4 KiB
Text
214 lines
4 KiB
Text
create table t1 (
|
|
pk int primary key,
|
|
a int,
|
|
b int
|
|
);
|
|
|
|
|
|
insert into t1 values
|
|
(11 , 0, 10),
|
|
(12 , 0, 10),
|
|
(13 , 1, 10),
|
|
(14 , 1, 10),
|
|
(18 , 2, 10),
|
|
(15 , 2, 20),
|
|
(16 , 2, 20),
|
|
(17 , 2, 20),
|
|
(19 , 4, 20),
|
|
(20 , 4, 20);
|
|
|
|
# TODO Try invalid queries too.
|
|
|
|
--error ER_INVALID_NTILE_ARGUMENT
|
|
select pk, a, b, ntile(-1) over (order by a)
|
|
from t1;
|
|
|
|
--error ER_INVALID_NTILE_ARGUMENT
|
|
select pk, a, b,
|
|
ntile(0) over (order by a)
|
|
from t1;
|
|
|
|
--sorted_result
|
|
select pk, a, b,
|
|
ntile(1) over (order by pk)
|
|
from t1;
|
|
|
|
--sorted_result
|
|
select pk, a, b,
|
|
ntile(2) over (order by pk)
|
|
from t1;
|
|
|
|
--sorted_result
|
|
select pk, a, b,
|
|
ntile(3) over (order by pk)
|
|
from t1;
|
|
|
|
--sorted_result
|
|
select pk, a, b,
|
|
ntile(4) over (order by pk)
|
|
from t1;
|
|
|
|
--sorted_result
|
|
select pk, a, b,
|
|
ntile(5) over (order by pk)
|
|
from t1;
|
|
|
|
--sorted_result
|
|
select pk, a, b,
|
|
ntile(6) over (order by pk)
|
|
from t1;
|
|
|
|
--sorted_result
|
|
select pk, a, b,
|
|
ntile(7) over (order by pk)
|
|
from t1;
|
|
|
|
--sorted_result
|
|
select pk, a, b,
|
|
ntile(8) over (order by pk)
|
|
from t1;
|
|
|
|
--sorted_result
|
|
select pk, a, b,
|
|
ntile(9) over (order by pk)
|
|
from t1;
|
|
|
|
--sorted_result
|
|
select pk, a, b,
|
|
ntile(10) over (order by pk)
|
|
from t1;
|
|
|
|
--sorted_result
|
|
select pk, a, b,
|
|
ntile(11) over (order by pk)
|
|
from t1;
|
|
|
|
--sorted_result
|
|
select pk, a, b,
|
|
ntile(20) over (order by pk)
|
|
from t1;
|
|
|
|
|
|
select pk, a, b,
|
|
ntile(1) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select pk, a, b,
|
|
ntile(2) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select pk, a, b,
|
|
ntile(3) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select pk, a, b,
|
|
ntile(4) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select pk, a, b,
|
|
ntile(5) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select pk, a, b,
|
|
ntile(6) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select pk, a, b,
|
|
ntile(7) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select pk, a, b,
|
|
ntile(8) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select pk, a, b,
|
|
ntile(9) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select pk, a, b,
|
|
ntile(10) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select pk, a, b,
|
|
ntile(11) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select pk, a, b,
|
|
ntile(20) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select pk, a, b,
|
|
ntile(1 + 3) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select pk, a, b,
|
|
ntile((select 4)) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select t1.a from t1 where pk = 11;
|
|
--error ER_INVALID_NTILE_ARGUMENT
|
|
select pk, a, b,
|
|
ntile((select a from t1 where pk=11)) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select t1.a from t1 where pk = 13;
|
|
select pk, a, b,
|
|
ntile((select a from t1 where pk=13)) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
explain
|
|
select pk, a, b,
|
|
ntile((select a from t1 where pk=13)) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
select a from t1;
|
|
--error ER_SUBQUERY_NO_1_ROW
|
|
select pk, a, b,
|
|
ntile((select a from t1)) over (partition by b order by pk)
|
|
from t1;
|
|
|
|
|
|
drop table t1;
|
|
|
|
--echo #
|
|
--echo # MDEV-9911 NTILE must return an error when parameter is not stable
|
|
--echo #
|
|
|
|
create table t1 (
|
|
pk int primary key,
|
|
c1 nvarchar(10),
|
|
c2 nvarchar(10),
|
|
c3 int
|
|
);
|
|
|
|
insert into t1 values
|
|
(1, 'Mark', 'Male', 5),
|
|
(2, 'John', 'Male', 5),
|
|
(3, 'Pam', 'Female', 6),
|
|
(4, 'Sara', 'Female', 6),
|
|
(5, 'Todd', 'Male', 5),
|
|
(6, 'Mary', 'Female', 6),
|
|
(7, 'Ben', 'Male', 5),
|
|
(8, 'Jodi', 'Female', 6),
|
|
(9, 'Tom', 'Male', 5),
|
|
(10, 'Lucky', 'Male', 5),
|
|
(11, 'Mark', 'Male', 5),
|
|
(12, 'John', 'Male', 5),
|
|
(13, 'Pam', 'Female', 6),
|
|
(14, 'Sara', 'Female', 6),
|
|
(15, 'Todd', 'Male', 5),
|
|
(16, 'Mary', 'Female', 6),
|
|
(17, 'Ben', 'Male', 5),
|
|
(18, 'Jodi', 'Female', 6),
|
|
(19, 'Tom', 'Male', 5),
|
|
(20, 'Lucky', 'Male', 5);
|
|
# Correct usage of NTILE with a fix argument NTILE(6).
|
|
select c1, c2, c3, ntile(6) over (partition by c2 order by pk) from t1;
|
|
# Correct usage - constant NTILE (argument) in each partition.
|
|
select c1, c2, c3, ntile(c3) over (partition by c2 order by pk) from t1;
|
|
|
|
update t1 set c3= 1 where pk = 1;
|
|
--error ER_INVALID_NTILE_ARGUMENT
|
|
select c1, c2, c3, ntile(c3) over (partition by c2 order by pk) from t1;
|
|
|
|
drop table t1;
|