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
3be81d42
Commit
3be81d42
authored
May 03, 2005
by
bell@book.sanja.is.com.ua
Browse files
Options
Browse Files
Download
Plain Diff
Merge book.sanja.is.com.ua:/Users/bell/mysql/bk/mysql-5.0
into book.sanja.is.com.ua:/Users/bell/mysql/bk/work-test-5.0
parents
ee3bb57a
4681d464
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
88 additions
and
1 deletion
+88
-1
BitKeeper/etc/logging_ok
BitKeeper/etc/logging_ok
+1
-0
sql/item.cc
sql/item.cc
+67
-1
sql/item.h
sql/item.h
+6
-0
sql/item_subselect.h
sql/item_subselect.h
+3
-0
sql/sql_base.cc
sql/sql_base.cc
+11
-0
No files found.
BitKeeper/etc/logging_ok
View file @
3be81d42
...
@@ -32,6 +32,7 @@ bar@mysql.com
...
@@ -32,6 +32,7 @@ bar@mysql.com
bar@noter.intranet.mysql.r18.ru
bar@noter.intranet.mysql.r18.ru
bell@51.0.168.192.in-addr.arpa
bell@51.0.168.192.in-addr.arpa
bell@52.0.168.192.in-addr.arpa
bell@52.0.168.192.in-addr.arpa
bell@book.sanja.is.com.ua
bell@laptop.sanja.is.com.ua
bell@laptop.sanja.is.com.ua
bell@sanja.is.com.ua
bell@sanja.is.com.ua
bk@admin.bk
bk@admin.bk
...
...
sql/item.cc
View file @
3be81d42
...
@@ -454,6 +454,7 @@ void Item_ident::cleanup()
...
@@ -454,6 +454,7 @@ void Item_ident::cleanup()
db_name
=
orig_db_name
;
db_name
=
orig_db_name
;
table_name
=
orig_table_name
;
table_name
=
orig_table_name
;
field_name
=
orig_field_name
;
field_name
=
orig_field_name
;
depended_from
=
0
;
DBUG_VOID_RETURN
;
DBUG_VOID_RETURN
;
}
}
...
@@ -2359,6 +2360,71 @@ static void mark_as_dependent(THD *thd, SELECT_LEX *last, SELECT_LEX *current,
...
@@ -2359,6 +2360,71 @@ static void mark_as_dependent(THD *thd, SELECT_LEX *last, SELECT_LEX *current,
}
}
/*
Mark range of selects and resolved identifier (field/reference) item as
dependent
SYNOPSIS
mark_select_range_as_dependent()
thd - thread handler
last_select - select where resolved_item was resolved
current_sel - current select (select where resolved_item was placed)
found_field - field which was found during resolving
found_item - Item which was found during resolving (if resolved
identifier belongs to VIEW)
resolved_item - Identifier which was resolved
NOTE:
We have to mark all items between current_sel (including) and
last_select (excluding) as dependend (select before last_select should
be marked with actual table mask used by resolved item, all other with
OUTER_REF_TABLE_BIT) and also write dependence information to Item of
resolved identifier.
*/
void
mark_select_range_as_dependent
(
THD
*
thd
,
SELECT_LEX
*
last_select
,
SELECT_LEX
*
current_sel
,
Field
*
found_field
,
Item
*
found_item
,
Item_ident
*
resolved_item
)
{
/*
Go from current SELECT to SELECT where field was resolved (it
have to be reachable from current SELECT, because it was already
done once when we resolved this field and cached result of
resolving)
*/
SELECT_LEX
*
previous_select
=
current_sel
;
for
(;
previous_select
->
outer_select
()
!=
last_select
;
previous_select
=
previous_select
->
outer_select
())
{
Item_subselect
*
prev_subselect_item
=
previous_select
->
master_unit
()
->
item
;
prev_subselect_item
->
used_tables_cache
|=
OUTER_REF_TABLE_BIT
;
prev_subselect_item
->
const_item_cache
=
0
;
}
{
Item_subselect
*
prev_subselect_item
=
previous_select
->
master_unit
()
->
item
;
Item_ident
*
dependent
=
resolved_item
;
if
(
found_field
==
view_ref_found
)
{
Item
::
Type
type
=
found_item
->
type
();
prev_subselect_item
->
used_tables_cache
|=
found_item
->
used_tables
();
dependent
=
((
type
==
Item
::
REF_ITEM
||
type
==
Item
::
FIELD_ITEM
)
?
(
Item_ident
*
)
found_item
:
0
);
}
else
prev_subselect_item
->
used_tables_cache
|=
found_field
->
table
->
map
;
prev_subselect_item
->
const_item_cache
=
0
;
mark_as_dependent
(
thd
,
last_select
,
current_sel
,
resolved_item
,
dependent
);
}
}
/*
/*
...
...
sql/item.h
View file @
3be81d42
...
@@ -1800,6 +1800,12 @@ public:
...
@@ -1800,6 +1800,12 @@ public:
static
enum_field_types
get_real_type
(
Item
*
);
static
enum_field_types
get_real_type
(
Item
*
);
};
};
class
st_select_lex
;
void
mark_select_range_as_dependent
(
THD
*
thd
,
st_select_lex
*
last_select
,
st_select_lex
*
current_sel
,
Field
*
found_field
,
Item
*
found_item
,
Item_ident
*
resolved_item
);
extern
Item_buff
*
new_Item_buff
(
Item
*
item
);
extern
Item_buff
*
new_Item_buff
(
Item
*
item
);
extern
Item_result
item_cmp_type
(
Item_result
a
,
Item_result
b
);
extern
Item_result
item_cmp_type
(
Item_result
a
,
Item_result
b
);
...
...
sql/item_subselect.h
View file @
3be81d42
...
@@ -122,6 +122,9 @@ public:
...
@@ -122,6 +122,9 @@ public:
friend
bool
Item_field
::
fix_fields
(
THD
*
,
TABLE_LIST
*
,
Item
**
);
friend
bool
Item_field
::
fix_fields
(
THD
*
,
TABLE_LIST
*
,
Item
**
);
friend
bool
Item_ref
::
fix_fields
(
THD
*
,
TABLE_LIST
*
,
Item
**
);
friend
bool
Item_ref
::
fix_fields
(
THD
*
,
TABLE_LIST
*
,
Item
**
);
friend
bool
Item_param
::
fix_fields
(
THD
*
,
TABLE_LIST
*
,
Item
**
);
friend
bool
Item_param
::
fix_fields
(
THD
*
,
TABLE_LIST
*
,
Item
**
);
friend
void
mark_select_range_as_dependent
(
THD
*
,
st_select_lex
*
,
st_select_lex
*
,
Field
*
,
Item
*
,
Item_ident
*
);
};
};
/* single value subselect */
/* single value subselect */
...
...
sql/sql_base.cc
View file @
3be81d42
...
@@ -2689,6 +2689,17 @@ find_field_in_tables(THD *thd, Item_ident *item, TABLE_LIST *tables,
...
@@ -2689,6 +2689,17 @@ find_field_in_tables(THD *thd, Item_ident *item, TABLE_LIST *tables,
{
{
if
(
found
==
WRONG_GRANT
)
if
(
found
==
WRONG_GRANT
)
return
(
Field
*
)
0
;
return
(
Field
*
)
0
;
{
SELECT_LEX
*
current_sel
=
thd
->
lex
->
current_select
;
SELECT_LEX
*
last_select
=
item
->
cached_table
->
select_lex
;
/*
If the field was an outer referencee, mark all selects using this
sub query as dependent of the outer query
*/
if
(
current_sel
!=
last_select
)
mark_select_range_as_dependent
(
thd
,
last_select
,
current_sel
,
found
,
*
ref
,
item
);
}
return
found
;
return
found
;
}
}
}
}
...
...
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