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
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
mariadb
Commits
69c2076c
Commit
69c2076c
authored
Nov 10, 2005
by
bell@sanja.is.com.ua
Browse files
Options
Browse Files
Download
Plain Diff
Merge sanja.is.com.ua:/home/bell/mysql/bk/mysql-5.0
into sanja.is.com.ua:/home/bell/mysql/bk/work-bug4-5.0
parents
0d4dbfd1
4f42b35b
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
139 additions
and
6 deletions
+139
-6
mysql-test/r/subselect_innodb.result
mysql-test/r/subselect_innodb.result
+72
-0
mysql-test/t/subselect_innodb.test
mysql-test/t/subselect_innodb.test
+54
-0
sql/opt_range.cc
sql/opt_range.cc
+13
-6
No files found.
mysql-test/r/subselect_innodb.result
View file @
69c2076c
...
@@ -172,3 +172,75 @@ group by country;
...
@@ -172,3 +172,75 @@ group by country;
countrycount smcnt country total_funds
countrycount smcnt country total_funds
1 1200 USA 1200
1 1200 USA 1200
drop table t1;
drop table t1;
CREATE TABLE `t1` (
`t3_id` int NOT NULL,
`t1_id` int NOT NULL,
PRIMARY KEY (`t1_id`)
);
CREATE TABLE `t2` (
`t2_id` int NOT NULL,
`t1_id` int NOT NULL,
`b` int NOT NULL,
PRIMARY KEY (`t2_id`),
UNIQUE KEY `idx_t2_t1_b` (`t1_id`,`b`)
) ENGINE=InnoDB;
CREATE TABLE `t3` (
`t3_id` int NOT NULL
);
INSERT INTO `t3` VALUES (3);
select
(SELECT rs.t2_id
FROM t2 rs
WHERE rs.t1_id=
(SELECT lt.t1_id
FROM t1 lt
WHERE lt.t3_id=a.t3_id)
ORDER BY b DESC LIMIT 1)
from t3 AS a;
(SELECT rs.t2_id
FROM t2 rs
WHERE rs.t1_id=
(SELECT lt.t1_id
FROM t1 lt
WHERE lt.t3_id=a.t3_id)
ORDER BY b DESC LIMIT 1)
NULL
DROP PROCEDURE IF EXISTS p1;
create procedure p1()
begin
declare done int default 3;
repeat
select
(SELECT rs.t2_id
FROM t2 rs
WHERE rs.t1_id=
(SELECT lt.t1_id
FROM t1 lt
WHERE lt.t3_id=a.t3_id)
ORDER BY b DESC LIMIT 1) as x
from t3 AS a;
set done= done-1;
until done <= 0 end repeat;
end//
call p1();
x
NULL
x
NULL
x
NULL
call p1();
x
NULL
x
NULL
x
NULL
call p1();
x
NULL
x
NULL
x
NULL
drop tables t1,t2,t3;
mysql-test/t/subselect_innodb.test
View file @
69c2076c
...
@@ -183,3 +183,57 @@ group by country;
...
@@ -183,3 +183,57 @@ group by country;
drop
table
t1
;
drop
table
t1
;
#
# BUG#14342: wrong placement of subquery internals in complex queries
#
CREATE
TABLE
`t1`
(
`t3_id`
int
NOT
NULL
,
`t1_id`
int
NOT
NULL
,
PRIMARY
KEY
(
`t1_id`
)
);
CREATE
TABLE
`t2`
(
`t2_id`
int
NOT
NULL
,
`t1_id`
int
NOT
NULL
,
`b`
int
NOT
NULL
,
PRIMARY
KEY
(
`t2_id`
),
UNIQUE
KEY
`idx_t2_t1_b`
(
`t1_id`
,
`b`
)
)
ENGINE
=
InnoDB
;
CREATE
TABLE
`t3`
(
`t3_id`
int
NOT
NULL
);
INSERT
INTO
`t3`
VALUES
(
3
);
select
(
SELECT
rs
.
t2_id
FROM
t2
rs
WHERE
rs
.
t1_id
=
(
SELECT
lt
.
t1_id
FROM
t1
lt
WHERE
lt
.
t3_id
=
a
.
t3_id
)
ORDER
BY
b
DESC
LIMIT
1
)
from
t3
AS
a
;
# repeat above query in SP
--
disable_warnings
DROP
PROCEDURE
IF
EXISTS
p1
;
--
enable_warnings
delimiter
//;
create
procedure
p1
()
begin
declare
done
int
default
3
;
repeat
select
(
SELECT
rs
.
t2_id
FROM
t2
rs
WHERE
rs
.
t1_id
=
(
SELECT
lt
.
t1_id
FROM
t1
lt
WHERE
lt
.
t3_id
=
a
.
t3_id
)
ORDER
BY
b
DESC
LIMIT
1
)
as
x
from
t3
AS
a
;
set
done
=
done
-
1
;
until
done
<=
0
end
repeat
;
end
//
delimiter
;
//
call
p1
();
call
p1
();
call
p1
();
drop
tables
t1
,
t2
,
t3
;
sql/opt_range.cc
View file @
69c2076c
...
@@ -5759,10 +5759,17 @@ QUICK_RANGE_SELECT *get_quick_select_for_ref(THD *thd, TABLE *table,
...
@@ -5759,10 +5759,17 @@ QUICK_RANGE_SELECT *get_quick_select_for_ref(THD *thd, TABLE *table,
MEM_ROOT
*
old_root
=
thd
->
mem_root
;
MEM_ROOT
*
old_root
=
thd
->
mem_root
;
/* The following call may change thd->mem_root */
/* The following call may change thd->mem_root */
QUICK_RANGE_SELECT
*
quick
=
new
QUICK_RANGE_SELECT
(
thd
,
table
,
ref
->
key
,
0
);
QUICK_RANGE_SELECT
*
quick
=
new
QUICK_RANGE_SELECT
(
thd
,
table
,
ref
->
key
,
0
);
/* save mem_root set by QUICK_RANGE_SELECT constructor */
MEM_ROOT
*
alloc
=
thd
->
mem_root
;
KEY
*
key_info
=
&
table
->
key_info
[
ref
->
key
];
KEY
*
key_info
=
&
table
->
key_info
[
ref
->
key
];
KEY_PART
*
key_part
;
KEY_PART
*
key_part
;
QUICK_RANGE
*
range
;
QUICK_RANGE
*
range
;
uint
part
;
uint
part
;
/*
return back default mem_root (thd->mem_root) changed by
QUICK_RANGE_SELECT constructor
*/
thd
->
mem_root
=
old_root
;
if
(
!
quick
)
if
(
!
quick
)
return
0
;
/* no ranges found */
return
0
;
/* no ranges found */
...
@@ -5774,7 +5781,7 @@ QUICK_RANGE_SELECT *get_quick_select_for_ref(THD *thd, TABLE *table,
...
@@ -5774,7 +5781,7 @@ QUICK_RANGE_SELECT *get_quick_select_for_ref(THD *thd, TABLE *table,
quick
->
records
=
records
;
quick
->
records
=
records
;
if
(
cp_buffer_from_ref
(
thd
,
ref
)
&&
thd
->
is_fatal_error
||
if
(
cp_buffer_from_ref
(
thd
,
ref
)
&&
thd
->
is_fatal_error
||
!
(
range
=
new
QUICK_RANGE
()))
!
(
range
=
new
(
alloc
)
QUICK_RANGE
()))
goto
err
;
// out of memory
goto
err
;
// out of memory
range
->
min_key
=
range
->
max_key
=
(
char
*
)
ref
->
key_buff
;
range
->
min_key
=
range
->
max_key
=
(
char
*
)
ref
->
key_buff
;
...
@@ -5809,20 +5816,20 @@ QUICK_RANGE_SELECT *get_quick_select_for_ref(THD *thd, TABLE *table,
...
@@ -5809,20 +5816,20 @@ QUICK_RANGE_SELECT *get_quick_select_for_ref(THD *thd, TABLE *table,
QUICK_RANGE
*
null_range
;
QUICK_RANGE
*
null_range
;
*
ref
->
null_ref_key
=
1
;
// Set null byte then create a range
*
ref
->
null_ref_key
=
1
;
// Set null byte then create a range
if
(
!
(
null_range
=
new
QUICK_RANGE
((
char
*
)
ref
->
key_buff
,
ref
->
key_length
,
if
(
!
(
null_range
=
new
(
alloc
)
QUICK_RANGE
((
char
*
)
ref
->
key_buff
,
(
char
*
)
ref
->
key_buff
,
ref
->
key_length
,
ref
->
key_length
,
EQ_RANGE
)))
(
char
*
)
ref
->
key_buff
,
ref
->
key_length
,
EQ_RANGE
)))
goto
err
;
goto
err
;
*
ref
->
null_ref_key
=
0
;
// Clear null byte
*
ref
->
null_ref_key
=
0
;
// Clear null byte
if
(
insert_dynamic
(
&
quick
->
ranges
,(
gptr
)
&
null_range
))
if
(
insert_dynamic
(
&
quick
->
ranges
,(
gptr
)
&
null_range
))
goto
err
;
goto
err
;
}
}
thd
->
mem_root
=
old_root
;
return
quick
;
return
quick
;
err:
err:
thd
->
mem_root
=
old_root
;
delete
quick
;
delete
quick
;
return
0
;
return
0
;
}
}
...
...
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