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
24baf74c
Commit
24baf74c
authored
Mar 17, 2004
by
paul@teton.kitebird.com
Browse files
Options
Browse Files
Download
Plain Diff
Merge paul@bk-internal.mysql.com:/home/bk/mysql-4.1
into teton.kitebird.com:/home/paul/mysql-4.1
parents
f71f7147
e8efe9c3
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
98 additions
and
26 deletions
+98
-26
include/my_base.h
include/my_base.h
+6
-2
innobase/dict/dict0dict.c
innobase/dict/dict0dict.c
+39
-1
innobase/include/dict0dict.h
innobase/include/dict0dict.h
+11
-0
innobase/include/row0mysql.h
innobase/include/row0mysql.h
+14
-7
sql/ha_innodb.cc
sql/ha_innodb.cc
+27
-15
sql/sql_select.cc
sql/sql_select.cc
+1
-1
No files found.
include/my_base.h
View file @
24baf74c
...
@@ -131,10 +131,14 @@ enum ha_extra_function {
...
@@ -131,10 +131,14 @@ enum ha_extra_function {
HA_EXTRA_IGNORE_DUP_KEY
,
/* Dup keys don't rollback everything*/
HA_EXTRA_IGNORE_DUP_KEY
,
/* Dup keys don't rollback everything*/
HA_EXTRA_NO_IGNORE_DUP_KEY
,
HA_EXTRA_NO_IGNORE_DUP_KEY
,
/*
/*
Instructs InnoDB to retrieve all columns
, not just those where
Instructs InnoDB to retrieve all columns
(except in key read), not just
field->query_id is the same as the current query id
those where
field->query_id is the same as the current query id
*/
*/
HA_EXTRA_RETRIEVE_ALL_COLS
,
HA_EXTRA_RETRIEVE_ALL_COLS
,
/*
Instructs InnoDB to retrieve at least all the primary key columns
*/
HA_EXTRA_RETRIEVE_PRIMARY_KEY
,
HA_EXTRA_PREPARE_FOR_DELETE
,
HA_EXTRA_PREPARE_FOR_DELETE
,
HA_EXTRA_PREPARE_FOR_UPDATE
,
/* Remove read cache if problems */
HA_EXTRA_PREPARE_FOR_UPDATE
,
/* Remove read cache if problems */
HA_EXTRA_PRELOAD_BUFFER_SIZE
/* Set buffer size for preloading */
HA_EXTRA_PRELOAD_BUFFER_SIZE
/* Set buffer size for preloading */
...
...
innobase/dict/dict0dict.c
View file @
24baf74c
...
@@ -631,7 +631,7 @@ dict_table_get_on_id(
...
@@ -631,7 +631,7 @@ dict_table_get_on_id(
}
}
/************************************************************************
/************************************************************************
Looks for column n postion in the clustered index. */
Looks for column n pos
i
tion in the clustered index. */
ulint
ulint
dict_table_get_nth_col_pos
(
dict_table_get_nth_col_pos
(
...
@@ -645,6 +645,44 @@ dict_table_get_nth_col_pos(
...
@@ -645,6 +645,44 @@ dict_table_get_nth_col_pos(
n
));
n
));
}
}
/************************************************************************
Checks if a column is in the ordering columns of the clustered index of a
table. Column prefixes are treated like whole columns. */
ibool
dict_table_col_in_clustered_key
(
/*============================*/
/* out: TRUE if the column, or its prefix, is
in the clustered key */
dict_table_t
*
table
,
/* in: table */
ulint
n
)
/* in: column number */
{
dict_index_t
*
index
;
dict_field_t
*
field
;
dict_col_t
*
col
;
ulint
pos
;
ulint
n_fields
;
ut_ad
(
table
);
col
=
dict_table_get_nth_col
(
table
,
n
);
index
=
dict_table_get_first_index
(
table
);
n_fields
=
dict_index_get_n_unique
(
index
);
for
(
pos
=
0
;
pos
<
n_fields
;
pos
++
)
{
field
=
dict_index_get_nth_field
(
index
,
pos
);
if
(
col
==
field
->
col
)
{
return
(
TRUE
);
}
}
return
(
FALSE
);
}
/**************************************************************************
/**************************************************************************
Inits the data dictionary module. */
Inits the data dictionary module. */
...
...
innobase/include/dict0dict.h
View file @
24baf74c
...
@@ -493,6 +493,17 @@ dict_table_get_sys_col_no(
...
@@ -493,6 +493,17 @@ dict_table_get_sys_col_no(
/* out: column number */
/* out: column number */
dict_table_t
*
table
,
/* in: table */
dict_table_t
*
table
,
/* in: table */
ulint
sys
);
/* in: DATA_ROW_ID, ... */
ulint
sys
);
/* in: DATA_ROW_ID, ... */
/************************************************************************
Checks if a column is in the ordering columns of the clustered index of a
table. Column prefixes are treated like whole columns. */
ibool
dict_table_col_in_clustered_key
(
/*============================*/
/* out: TRUE if the column, or its prefix, is
in the clustered key */
dict_table_t
*
table
,
/* in: table */
ulint
n
);
/* in: column number */
/***********************************************************************
/***********************************************************************
Copies types of columns contained in table to tuple. */
Copies types of columns contained in table to tuple. */
...
...
innobase/include/row0mysql.h
View file @
24baf74c
...
@@ -510,13 +510,15 @@ struct row_prebuilt_struct {
...
@@ -510,13 +510,15 @@ struct row_prebuilt_struct {
byte
*
ins_upd_rec_buff
;
/* buffer for storing data converted
byte
*
ins_upd_rec_buff
;
/* buffer for storing data converted
to the Innobase format from the MySQL
to the Innobase format from the MySQL
format */
format */
ibool
hint_no_need_to_fetch_extra_cols
;
ulint
hint_need_to_fetch_extra_cols
;
/* normally this is TRUE, but
/* normally this is set to 0; if this
MySQL will set this to FALSE
is set to ROW_RETRIEVE_PRIMARY_KEY,
if we might be required to fetch also
then we should at least retrieve all
other columns than mentioned in the
columns in the primary key; if this
query: the clustered index column(s),
is set to ROW_RETRIEVE_ALL_COLS, then
or an auto-increment column*/
we must retrieve all columns in the
key (if read_just_key == 1), or all
columns in the table */
upd_node_t
*
upd_node
;
/* Innobase SQL update node used
upd_node_t
*
upd_node
;
/* Innobase SQL update node used
to perform updates and deletes */
to perform updates and deletes */
que_fork_t
*
ins_graph
;
/* Innobase SQL query graph used
que_fork_t
*
ins_graph
;
/* Innobase SQL query graph used
...
@@ -572,6 +574,11 @@ struct row_prebuilt_struct {
...
@@ -572,6 +574,11 @@ struct row_prebuilt_struct {
#define ROW_MYSQL_DUMMY_TEMPLATE 3
/* dummy template used in
#define ROW_MYSQL_DUMMY_TEMPLATE 3
/* dummy template used in
row_scan_and_check_index */
row_scan_and_check_index */
/* Values for hint_need_to_fetch_extra_cols */
#define ROW_RETRIEVE_PRIMARY_KEY 1
#define ROW_RETRIEVE_ALL_COLS 2
#ifndef UNIV_NONINL
#ifndef UNIV_NONINL
#include "row0mysql.ic"
#include "row0mysql.ic"
#endif
#endif
...
...
sql/ha_innodb.cc
View file @
24baf74c
...
@@ -702,7 +702,7 @@ ha_innobase::init_table_handle_for_HANDLER(void)
...
@@ -702,7 +702,7 @@ ha_innobase::init_table_handle_for_HANDLER(void)
/* Always fetch all columns in the index record */
/* Always fetch all columns in the index record */
prebuilt
->
hint_n
o_need_to_fetch_extra_cols
=
FALSE
;
prebuilt
->
hint_n
eed_to_fetch_extra_cols
=
ROW_RETRIEVE_ALL_COLS
;
/* We want always to fetch all columns in the whole row? Or do
/* We want always to fetch all columns in the whole row? Or do
we???? */
we???? */
...
@@ -1951,6 +1951,7 @@ build_template(
...
@@ -1951,6 +1951,7 @@ build_template(
ulint
n_fields
;
ulint
n_fields
;
ulint
n_requested_fields
=
0
;
ulint
n_requested_fields
=
0
;
ibool
fetch_all_in_key
=
FALSE
;
ibool
fetch_all_in_key
=
FALSE
;
ibool
fetch_primary_key_cols
=
FALSE
;
ulint
i
;
ulint
i
;
if
(
prebuilt
->
select_lock_type
==
LOCK_X
)
{
if
(
prebuilt
->
select_lock_type
==
LOCK_X
)
{
...
@@ -1961,8 +1962,9 @@ build_template(
...
@@ -1961,8 +1962,9 @@ build_template(
templ_type
=
ROW_MYSQL_WHOLE_ROW
;
templ_type
=
ROW_MYSQL_WHOLE_ROW
;
}
}
if
(
templ_type
==
ROW_MYSQL_REC_FIELDS
if
(
templ_type
==
ROW_MYSQL_REC_FIELDS
)
{
&&
!
prebuilt
->
hint_no_need_to_fetch_extra_cols
)
{
if
(
prebuilt
->
hint_need_to_fetch_extra_cols
==
ROW_RETRIEVE_ALL_COLS
)
{
/* We know we must at least fetch all columns in the key, or
/* We know we must at least fetch all columns in the key, or
all columns in the table */
all columns in the table */
...
@@ -1977,15 +1979,14 @@ build_template(
...
@@ -1977,15 +1979,14 @@ build_template(
fetch_all_in_key
=
TRUE
;
fetch_all_in_key
=
TRUE
;
}
else
{
}
else
{
/* We are building a temporary table: fetch all
columns; the reason is that MySQL may use the
clustered index key to store rows, but the mechanism
we use below to detect required columns does not
reveal that. Actually, it might be enough to
fetch only all in the key also in this case! */
templ_type
=
ROW_MYSQL_WHOLE_ROW
;
templ_type
=
ROW_MYSQL_WHOLE_ROW
;
}
}
}
else
if
(
prebuilt
->
hint_need_to_fetch_extra_cols
==
ROW_RETRIEVE_PRIMARY_KEY
)
{
/* We must at least fetch all primary key cols */
fetch_primary_key_cols
=
TRUE
;
}
}
}
clust_index
=
dict_table_get_first_index_noninline
(
prebuilt
->
table
);
clust_index
=
dict_table_get_first_index_noninline
(
prebuilt
->
table
);
...
@@ -2004,7 +2005,7 @@ build_template(
...
@@ -2004,7 +2005,7 @@ build_template(
the clustered index */
the clustered index */
}
}
n_fields
=
(
ulint
)
table
->
fields
;
n_fields
=
(
ulint
)
table
->
fields
;
/* number of columns */
if
(
!
prebuilt
->
mysql_template
)
{
if
(
!
prebuilt
->
mysql_template
)
{
prebuilt
->
mysql_template
=
(
mysql_row_templ_t
*
)
prebuilt
->
mysql_template
=
(
mysql_row_templ_t
*
)
...
@@ -2017,6 +2018,8 @@ build_template(
...
@@ -2017,6 +2018,8 @@ build_template(
prebuilt
->
templ_contains_blob
=
FALSE
;
prebuilt
->
templ_contains_blob
=
FALSE
;
/* Note that in InnoDB, i is the column number. MySQL calls columns
'fields'. */
for
(
i
=
0
;
i
<
n_fields
;
i
++
)
{
for
(
i
=
0
;
i
<
n_fields
;
i
++
)
{
templ
=
prebuilt
->
mysql_template
+
n_requested_fields
;
templ
=
prebuilt
->
mysql_template
+
n_requested_fields
;
field
=
table
->
field
[
i
];
field
=
table
->
field
[
i
];
...
@@ -2029,6 +2032,8 @@ build_template(
...
@@ -2029,6 +2032,8 @@ build_template(
if
(
templ_type
==
ROW_MYSQL_REC_FIELDS
if
(
templ_type
==
ROW_MYSQL_REC_FIELDS
&&
!
(
fetch_all_in_key
&&
!
(
fetch_all_in_key
&&
dict_index_contains_col_or_prefix
(
index
,
i
))
&&
dict_index_contains_col_or_prefix
(
index
,
i
))
&&
!
(
fetch_primary_key_cols
&&
dict_table_col_in_clustered_key
(
index
->
table
,
i
))
&&
thd
->
query_id
!=
field
->
query_id
)
{
&&
thd
->
query_id
!=
field
->
query_id
)
{
/* This field is not needed in the query, skip it */
/* This field is not needed in the query, skip it */
...
@@ -4514,7 +4519,14 @@ ha_innobase::extra(
...
@@ -4514,7 +4519,14 @@ ha_innobase::extra(
prebuilt
->
read_just_key
=
0
;
prebuilt
->
read_just_key
=
0
;
break
;
break
;
case
HA_EXTRA_RETRIEVE_ALL_COLS
:
case
HA_EXTRA_RETRIEVE_ALL_COLS
:
prebuilt
->
hint_no_need_to_fetch_extra_cols
=
FALSE
;
prebuilt
->
hint_need_to_fetch_extra_cols
=
ROW_RETRIEVE_ALL_COLS
;
break
;
case
HA_EXTRA_RETRIEVE_PRIMARY_KEY
:
if
(
prebuilt
->
hint_need_to_fetch_extra_cols
==
0
)
{
prebuilt
->
hint_need_to_fetch_extra_cols
=
ROW_RETRIEVE_PRIMARY_KEY
;
}
break
;
break
;
case
HA_EXTRA_KEYREAD
:
case
HA_EXTRA_KEYREAD
:
prebuilt
->
read_just_key
=
1
;
prebuilt
->
read_just_key
=
1
;
...
@@ -4575,7 +4587,7 @@ ha_innobase::start_stmt(
...
@@ -4575,7 +4587,7 @@ ha_innobase::start_stmt(
auto_inc_counter_for_this_stat
=
0
;
auto_inc_counter_for_this_stat
=
0
;
prebuilt
->
sql_stat_start
=
TRUE
;
prebuilt
->
sql_stat_start
=
TRUE
;
prebuilt
->
hint_n
o_need_to_fetch_extra_cols
=
TRUE
;
prebuilt
->
hint_n
eed_to_fetch_extra_cols
=
0
;
prebuilt
->
read_just_key
=
0
;
prebuilt
->
read_just_key
=
0
;
if
(
!
prebuilt
->
mysql_has_locked
)
{
if
(
!
prebuilt
->
mysql_has_locked
)
{
...
@@ -4652,7 +4664,7 @@ ha_innobase::external_lock(
...
@@ -4652,7 +4664,7 @@ ha_innobase::external_lock(
trx
=
prebuilt
->
trx
;
trx
=
prebuilt
->
trx
;
prebuilt
->
sql_stat_start
=
TRUE
;
prebuilt
->
sql_stat_start
=
TRUE
;
prebuilt
->
hint_n
o_need_to_fetch_extra_cols
=
TRUE
;
prebuilt
->
hint_n
eed_to_fetch_extra_cols
=
0
;
prebuilt
->
read_just_key
=
0
;
prebuilt
->
read_just_key
=
0
;
...
@@ -4996,7 +5008,7 @@ ha_innobase::innobase_read_and_init_auto_inc(
...
@@ -4996,7 +5008,7 @@ ha_innobase::innobase_read_and_init_auto_inc(
/* Play safe and also give in another way the hint to fetch
/* Play safe and also give in another way the hint to fetch
all columns in the key: */
all columns in the key: */
prebuilt
->
hint_n
o_need_to_fetch_extra_cols
=
FALSE
;
prebuilt
->
hint_n
eed_to_fetch_extra_cols
=
ROW_RETRIEVE_ALL_COLS
;
prebuilt
->
trx
->
mysql_n_tables_locked
+=
1
;
prebuilt
->
trx
->
mysql_n_tables_locked
+=
1
;
...
...
sql/sql_select.cc
View file @
24baf74c
...
@@ -845,7 +845,7 @@ JOIN::optimize()
...
@@ -845,7 +845,7 @@ JOIN::optimize()
for
(
uint
i_h
=
const_tables
;
i_h
<
tables
;
i_h
++
)
for
(
uint
i_h
=
const_tables
;
i_h
<
tables
;
i_h
++
)
{
{
TABLE
*
table_h
=
join_tab
[
i_h
].
table
;
TABLE
*
table_h
=
join_tab
[
i_h
].
table
;
table_h
->
file
->
extra
(
HA_EXTRA_RETRIEVE_
ALL_COLS
);
table_h
->
file
->
extra
(
HA_EXTRA_RETRIEVE_
PRIMARY_KEY
);
}
}
}
}
#endif
#endif
...
...
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