Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
76f4f23f
Commit
76f4f23f
authored
Jun 11, 2007
by
evgen@moonbone.local
Browse files
Options
Browse Files
Download
Plain Diff
Merge moonbone.local:/mnt/gentoo64/work/test-5.0-opt-mysql
into moonbone.local:/mnt/gentoo64/work/test-5.1-opt-mysql
parents
dcc1d822
2d29a57f
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
69 additions
and
8 deletions
+69
-8
mysql-test/r/subselect.result
mysql-test/r/subselect.result
+26
-0
mysql-test/t/subselect.test
mysql-test/t/subselect.test
+32
-0
sql/filesort.cc
sql/filesort.cc
+11
-8
No files found.
mysql-test/r/subselect.result
View file @
76f4f23f
...
@@ -4074,6 +4074,32 @@ CREATE TABLE t1 (a int);
...
@@ -4074,6 +4074,32 @@ CREATE TABLE t1 (a int);
INSERT INTO t1 VALUES (1), (2);
INSERT INTO t1 VALUES (1), (2);
EXPLAIN EXTENDED
EXPLAIN EXTENDED
SELECT * FROM (SELECT count(*) FROM t1 GROUP BY a) as res;
SELECT * FROM (SELECT count(*) FROM t1 GROUP BY a) as res;
CREATE TABLE t1 (
a varchar(255) default NULL,
b timestamp NOT NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP,
INDEX idx(a,b)
);
CREATE TABLE t2 (
a varchar(255) default NULL
);
INSERT INTO t1 VALUES ('abcdefghijk','2007-05-07 06:00:24');
INSERT INTO t1 SELECT * FROM t1;
INSERT INTO t1 SELECT * FROM t1;
INSERT INTO t1 SELECT * FROM t1;
INSERT INTO t1 SELECT * FROM t1;
INSERT INTO t1 SELECT * FROM t1;
INSERT INTO t1 SELECT * FROM t1;
INSERT INTO t1 SELECT * FROM t1;
INSERT INTO t1 SELECT * FROM t1;
INSERT INTO `t1` VALUES ('asdf','2007-02-08 01:11:26');
INSERT INTO `t2` VALUES ('abcdefghijk');
INSERT INTO `t2` VALUES ('asdf');
SET session sort_buffer_size=8192;
SELECT (SELECT 1 FROM t1 WHERE t1.a=t2.a ORDER BY t1.b LIMIT 1) AS d1 FROM t2;
d1
1
1
DROP TABLE t1,t2;
id select_type table type possible_keys key key_len ref rows filtered Extra
id select_type table type possible_keys key key_len ref rows filtered Extra
1 PRIMARY <derived2> ALL NULL NULL NULL NULL 2 100.00
1 PRIMARY <derived2> ALL NULL NULL NULL NULL 2 100.00
2 DERIVED t1 ALL NULL NULL NULL NULL 2 100.00 Using temporary; Using filesort
2 DERIVED t1 ALL NULL NULL NULL NULL 2 100.00 Using temporary; Using filesort
...
...
mysql-test/t/subselect.test
View file @
76f4f23f
...
@@ -2913,6 +2913,38 @@ SELECT * FROM (SELECT count(*) FROM t1 GROUP BY a) as res;
...
@@ -2913,6 +2913,38 @@ SELECT * FROM (SELECT count(*) FROM t1 GROUP BY a) as res;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
#
# Bug #28811: crash for query containing subquery with ORDER BY and LIMIT 1
#
CREATE
TABLE
t1
(
a
varchar
(
255
)
default
NULL
,
b
timestamp
NOT
NULL
default
CURRENT_TIMESTAMP
on
update
CURRENT_TIMESTAMP
,
INDEX
idx
(
a
,
b
)
);
CREATE
TABLE
t2
(
a
varchar
(
255
)
default
NULL
);
INSERT
INTO
t1
VALUES
(
'abcdefghijk'
,
'2007-05-07 06:00:24'
);
INSERT
INTO
t1
SELECT
*
FROM
t1
;
INSERT
INTO
t1
SELECT
*
FROM
t1
;
INSERT
INTO
t1
SELECT
*
FROM
t1
;
INSERT
INTO
t1
SELECT
*
FROM
t1
;
INSERT
INTO
t1
SELECT
*
FROM
t1
;
INSERT
INTO
t1
SELECT
*
FROM
t1
;
INSERT
INTO
t1
SELECT
*
FROM
t1
;
INSERT
INTO
t1
SELECT
*
FROM
t1
;
INSERT
INTO
`t1`
VALUES
(
'asdf'
,
'2007-02-08 01:11:26'
);
INSERT
INTO
`t2`
VALUES
(
'abcdefghijk'
);
INSERT
INTO
`t2`
VALUES
(
'asdf'
);
SET
session
sort_buffer_size
=
8192
;
SELECT
(
SELECT
1
FROM
t1
WHERE
t1
.
a
=
t2
.
a
ORDER
BY
t1
.
b
LIMIT
1
)
AS
d1
FROM
t2
;
DROP
TABLE
t1
,
t2
;
--
echo
End
of
5.0
tests
.
--
echo
End
of
5.0
tests
.
#
#
...
...
sql/filesort.cc
View file @
76f4f23f
...
@@ -35,7 +35,8 @@ if (my_b_write((file),(uchar*) (from),param->ref_length)) \
...
@@ -35,7 +35,8 @@ if (my_b_write((file),(uchar*) (from),param->ref_length)) \
/* functions defined in this file */
/* functions defined in this file */
static
char
**
make_char_array
(
register
uint
fields
,
uint
length
,
myf
my_flag
);
static
char
**
make_char_array
(
char
**
old_pos
,
register
uint
fields
,
uint
length
,
myf
my_flag
);
static
BUFFPEK
*
read_buffpek_from_file
(
IO_CACHE
*
buffer_file
,
uint
count
);
static
BUFFPEK
*
read_buffpek_from_file
(
IO_CACHE
*
buffer_file
,
uint
count
);
static
ha_rows
find_all_keys
(
SORTPARAM
*
param
,
SQL_SELECT
*
select
,
static
ha_rows
find_all_keys
(
SORTPARAM
*
param
,
SQL_SELECT
*
select
,
uchar
*
*
sort_keys
,
IO_CACHE
*
buffer_file
,
uchar
*
*
sort_keys
,
IO_CACHE
*
buffer_file
,
...
@@ -208,9 +209,9 @@ ha_rows filesort(THD *thd, TABLE *table, SORT_FIELD *sortorder, uint s_length,
...
@@ -208,9 +209,9 @@ ha_rows filesort(THD *thd, TABLE *table, SORT_FIELD *sortorder, uint s_length,
ulong
old_memavl
;
ulong
old_memavl
;
ulong
keys
=
memavl
/
(
param
.
rec_length
+
sizeof
(
char
*
));
ulong
keys
=
memavl
/
(
param
.
rec_length
+
sizeof
(
char
*
));
param
.
keys
=
(
uint
)
min
(
records
+
1
,
keys
);
param
.
keys
=
(
uint
)
min
(
records
+
1
,
keys
);
if
(
table_sort
.
sort_keys
||
if
(
(
table_sort
.
sort_keys
=
(
table_sort
.
sort_keys
=
(
uchar
**
)
make_char_array
(
param
.
keys
,
param
.
rec_length
,
(
uchar
**
)
make_char_array
((
char
**
)
table_sort
.
sort_keys
,
MYF
(
0
))))
param
.
keys
,
param
.
rec_length
,
MYF
(
0
))))
break
;
break
;
old_memavl
=
memavl
;
old_memavl
=
memavl
;
if
((
memavl
=
memavl
/
4
*
3
)
<
min_sort_memory
&&
old_memavl
>
min_sort_memory
)
if
((
memavl
=
memavl
/
4
*
3
)
<
min_sort_memory
&&
old_memavl
>
min_sort_memory
)
...
@@ -352,13 +353,15 @@ void filesort_free_buffers(TABLE *table, bool full)
...
@@ -352,13 +353,15 @@ void filesort_free_buffers(TABLE *table, bool full)
/* Make a array of string pointers */
/* Make a array of string pointers */
static
char
**
make_char_array
(
register
uint
fields
,
uint
length
,
myf
my_flag
)
static
char
**
make_char_array
(
char
**
old_pos
,
register
uint
fields
,
uint
length
,
myf
my_flag
)
{
{
register
char
**
pos
;
register
char
**
pos
;
char
*
*
old_pos
,
*
char_pos
;
char
*
char_pos
;
DBUG_ENTER
(
"make_char_array"
);
DBUG_ENTER
(
"make_char_array"
);
if
((
old_pos
=
(
char
**
)
my_malloc
((
uint
)
fields
*
(
length
+
sizeof
(
char
*
)),
if
(
old_pos
||
(
old_pos
=
(
char
**
)
my_malloc
((
uint
)
fields
*
(
length
+
sizeof
(
char
*
)),
my_flag
)))
my_flag
)))
{
{
pos
=
old_pos
;
char_pos
=
((
char
*
)
(
pos
+
fields
))
-
length
;
pos
=
old_pos
;
char_pos
=
((
char
*
)
(
pos
+
fields
))
-
length
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment