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
786f8232
Commit
786f8232
authored
Mar 18, 2004
by
pem@mysql.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge
parents
6c6bbba0
d7e5bbd6
Changes
8
Hide whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
80 additions
and
1 deletion
+80
-1
mysql-test/r/index_merge.result
mysql-test/r/index_merge.result
+20
-0
mysql-test/r/sp.result
mysql-test/r/sp.result
+6
-0
mysql-test/t/index_merge.test
mysql-test/t/index_merge.test
+10
-0
mysql-test/t/sp.test
mysql-test/t/sp.test
+10
-0
sql/opt_range.h
sql/opt_range.h
+9
-0
sql/sp.cc
sql/sp.cc
+14
-1
sql/sql_delete.cc
sql/sql_delete.cc
+7
-0
sql/sql_update.cc
sql/sql_update.cc
+4
-0
No files found.
mysql-test/r/index_merge.result
View file @
786f8232
...
@@ -314,4 +314,24 @@ key1 key2 key3 key4 key5 key6 key7 key8 key9 keyA keyB keyC
...
@@ -314,4 +314,24 @@ key1 key2 key3 key4 key5 key6 key7 key8 key9 keyA keyB keyC
11 11 11 11 11 11 11 1013 11 11 11 11
11 11 11 11 11 11 11 1013 11 11 11 11
12 12 12 12 12 12 12 1012 12 12 12 12
12 12 12 12 12 12 12 1012 12 12 12 12
1016 1016 1016 1016 1016 1016 1016 8 1016 1016 1016 1016
1016 1016 1016 1016 1016 1016 1016 8 1016 1016 1016 1016
explain select * from t0 where key1 < 3 or key2 < 4;
id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE t0 index_merge i1,i2 i1,i2 4,4 NULL 7 Using where
select * from t0 where key1 < 3 or key2 < 4;
key1 key2 key3 key4 key5 key6 key7 key8
1 1 1 1 1 1 1 1023
2 2 2 2 2 2 2 1022
3 3 3 3 3 3 3 1021
update t0 set key8=123 where key1 < 3 or key2 < 4;
select * from t0 where key1 < 3 or key2 < 4;
key1 key2 key3 key4 key5 key6 key7 key8
1 1 1 1 1 1 1 123
2 2 2 2 2 2 2 123
3 3 3 3 3 3 3 123
delete from t0 where key1 < 3 or key2 < 4;
select * from t0 where key1 < 3 or key2 < 4;
key1 key2 key3 key4 key5 key6 key7 key8
select count(*) from t0;
count(*)
1021
drop table t0, t1, t2, t3, t4;
drop table t0, t1, t2, t3, t4;
mysql-test/r/sp.result
View file @
786f8232
...
@@ -978,6 +978,12 @@ call bug2614()|
...
@@ -978,6 +978,12 @@ call bug2614()|
call bug2614()|
call bug2614()|
drop table t3|
drop table t3|
drop procedure bug2614|
drop procedure bug2614|
create function bug2674 () returns int
return @@sort_buffer_size|
select bug2674()|
bug2674()
262136
drop function bug2674|
drop table if exists fac|
drop table if exists fac|
create table fac (n int unsigned not null primary key, f bigint unsigned)|
create table fac (n int unsigned not null primary key, f bigint unsigned)|
create procedure ifac(n int unsigned)
create procedure ifac(n int unsigned)
...
...
mysql-test/t/index_merge.test
View file @
786f8232
...
@@ -267,5 +267,15 @@ select * from t3 where
...
@@ -267,5 +267,15 @@ select * from t3 where
key5
=
5
or
key6
=
6
or
key7
=
7
or
key8
=
8
or
key5
=
5
or
key6
=
6
or
key7
=
7
or
key8
=
8
or
key9
=
9
or
keyA
=
10
or
keyB
=
11
or
keyC
=
12
;
key9
=
9
or
keyA
=
10
or
keyB
=
11
or
keyC
=
12
;
# Test for Bug#3183
explain
select
*
from
t0
where
key1
<
3
or
key2
<
4
;
select
*
from
t0
where
key1
<
3
or
key2
<
4
;
update
t0
set
key8
=
123
where
key1
<
3
or
key2
<
4
;
select
*
from
t0
where
key1
<
3
or
key2
<
4
;
delete
from
t0
where
key1
<
3
or
key2
<
4
;
select
*
from
t0
where
key1
<
3
or
key2
<
4
;
select
count
(
*
)
from
t0
;
drop
table
t0
,
t1
,
t2
,
t3
,
t4
;
drop
table
t0
,
t1
,
t2
,
t3
,
t4
;
mysql-test/t/sp.test
View file @
786f8232
...
@@ -1123,6 +1123,16 @@ call bug2614()|
...
@@ -1123,6 +1123,16 @@ call bug2614()|
drop
table
t3
|
drop
table
t3
|
drop
procedure
bug2614
|
drop
procedure
bug2614
|
#
# BUG#2674
#
create
function
bug2674
()
returns
int
return
@@
sort_buffer_size
|
select
bug2674
()
|
drop
function
bug2674
|
#
#
# Some "real" examples
# Some "real" examples
...
...
sql/opt_range.h
View file @
786f8232
...
@@ -87,7 +87,16 @@ public:
...
@@ -87,7 +87,16 @@ public:
QUICK_SELECT_I
();
QUICK_SELECT_I
();
virtual
~
QUICK_SELECT_I
(){};
virtual
~
QUICK_SELECT_I
(){};
/*
Call init() immediately after creation of quick select. if init() call
fails, reset() or get_next() must not be called.
*/
virtual
int
init
()
=
0
;
virtual
int
init
()
=
0
;
/*
Call reset() before first get_next call. get_next must not be called if
reset() call fails.
*/
virtual
int
reset
(
void
)
=
0
;
virtual
int
reset
(
void
)
=
0
;
virtual
int
get_next
()
=
0
;
/* get next record to retrieve */
virtual
int
get_next
()
=
0
;
/* get next record to retrieve */
virtual
bool
reverse_sorted
()
=
0
;
virtual
bool
reverse_sorted
()
=
0
;
...
...
sql/sp.cc
View file @
786f8232
...
@@ -242,7 +242,20 @@ db_find_routine(THD *thd, int type, sp_name *name, sp_head **sphp)
...
@@ -242,7 +242,20 @@ db_find_routine(THD *thd, int type, sp_name *name, sp_head **sphp)
if
((
ret
=
sp_use_new_db
(
thd
,
name
->
m_db
.
str
,
olddb
,
sizeof
(
olddb
),
1
)))
if
((
ret
=
sp_use_new_db
(
thd
,
name
->
m_db
.
str
,
olddb
,
sizeof
(
olddb
),
1
)))
goto
done
;
goto
done
;
lex_start
(
thd
,
(
uchar
*
)
defstr
,
deflen
);
{
/* This is something of a kludge. We need to initialize some fields
* in thd->lex (the unit and master stuff), and the easiest way to
* do it is, is to call mysql_init_query(), but this unfortunately
* resets teh value_list where we keep the CALL parameters. So we
* copy the list and then restore it.
*/
List
<
Item
>
vals
=
thd
->
lex
->
value_list
;
mysql_init_query
(
thd
,
TRUE
);
lex_start
(
thd
,
(
uchar
*
)
defstr
,
deflen
);
thd
->
lex
->
value_list
=
vals
;
}
if
(
yyparse
(
thd
)
||
thd
->
is_fatal_error
||
thd
->
lex
->
sphead
==
NULL
)
if
(
yyparse
(
thd
)
||
thd
->
is_fatal_error
||
thd
->
lex
->
sphead
==
NULL
)
{
{
LEX
*
newlex
=
thd
->
lex
;
LEX
*
newlex
=
thd
->
lex
;
...
...
sql/sql_delete.cc
View file @
786f8232
...
@@ -150,6 +150,13 @@ int mysql_delete(THD *thd, TABLE_LIST *table_list, COND *conds, SQL_LIST *order,
...
@@ -150,6 +150,13 @@ int mysql_delete(THD *thd, TABLE_LIST *table_list, COND *conds, SQL_LIST *order,
select
=
0
;
select
=
0
;
}
}
/* If quick select is used, initialize it before retrieving rows. */
if
(
select
&&
select
->
quick
&&
select
->
quick
->
reset
())
{
delete
select
;
free_underlaid_joins
(
thd
,
&
thd
->
lex
->
select_lex
);
DBUG_RETURN
(
-
1
);
// This will force out message
}
init_read_record
(
&
info
,
thd
,
table
,
select
,
1
,
1
);
init_read_record
(
&
info
,
thd
,
table
,
select
,
1
,
1
);
deleted
=
0L
;
deleted
=
0L
;
init_ftfuncs
(
thd
,
&
thd
->
lex
->
select_lex
,
1
);
init_ftfuncs
(
thd
,
&
thd
->
lex
->
select_lex
,
1
);
...
...
sql/sql_update.cc
View file @
786f8232
...
@@ -246,7 +246,11 @@ int mysql_update(THD *thd,
...
@@ -246,7 +246,11 @@ int mysql_update(THD *thd,
DISK_BUFFER_SIZE
,
MYF
(
MY_WME
)))
DISK_BUFFER_SIZE
,
MYF
(
MY_WME
)))
goto
err
;
goto
err
;
/* If quick select is used, initialize it before retrieving rows. */
if
(
select
&&
select
->
quick
&&
select
->
quick
->
reset
())
goto
err
;
init_read_record
(
&
info
,
thd
,
table
,
select
,
0
,
1
);
init_read_record
(
&
info
,
thd
,
table
,
select
,
0
,
1
);
thd
->
proc_info
=
"Searching rows for update"
;
thd
->
proc_info
=
"Searching rows for update"
;
uint
tmp_limit
=
limit
;
uint
tmp_limit
=
limit
;
...
...
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