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
f5f65c40
Commit
f5f65c40
authored
Aug 21, 2007
by
gshchepa/uchum@gleb.loc
Browse files
Options
Browse Files
Download
Plain Diff
Merge gleb.loc:/home/uchum/work/bk/5.0-opt-30287
into gleb.loc:/home/uchum/work/bk/5.1-opt
parents
1640c5ce
5d3809c2
Changes
3
Show whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
16 additions
and
10 deletions
+16
-10
sql/item.cc
sql/item.cc
+2
-0
sql/sql_select.cc
sql/sql_select.cc
+8
-10
sql/sql_view.cc
sql/sql_view.cc
+6
-0
No files found.
sql/item.cc
View file @
f5f65c40
...
...
@@ -1801,6 +1801,8 @@ void Item_field::set_field(Field *field_par)
unsigned_flag
=
test
(
field_par
->
flags
&
UNSIGNED_FLAG
);
collation
.
set
(
field_par
->
charset
(),
field_par
->
derivation
());
fixed
=
1
;
if
(
field
->
table
->
s
->
tmp_table
==
SYSTEM_TMP_TABLE
)
any_privileges
=
0
;
}
...
...
sql/sql_select.cc
View file @
f5f65c40
...
...
@@ -9404,7 +9404,7 @@ create_tmp_table(THD *thd,TMP_TABLE_PARAM *param,List<Item> &fields,
bool
using_unique_constraint
=
0
;
bool
use_packed_rows
=
0
;
bool
not_all_columns
=
!
(
select_options
&
TMP_TABLE_ALL_COLUMNS
);
char
*
tmpname
,
*
tmppath
,
path
[
FN_REFLEN
],
table_name
[
NAME_LEN
+
1
];
char
*
tmpname
,
path
[
FN_REFLEN
];
uchar
*
pos
,
*
group_buff
,
*
bitmaps
;
uchar
*
null_flags
;
Field
**
reg_field
,
**
from_field
,
**
default_field
;
...
...
@@ -9428,12 +9428,12 @@ create_tmp_table(THD *thd,TMP_TABLE_PARAM *param,List<Item> &fields,
temp_pool_slot
=
bitmap_lock_set_next
(
&
temp_pool
);
if
(
temp_pool_slot
!=
MY_BIT_NONE
)
// we got a slot
sprintf
(
table_name
,
"%s_%lx_%i"
,
tmp_file_prefix
,
sprintf
(
path
,
"%s_%lx_%i"
,
tmp_file_prefix
,
current_pid
,
temp_pool_slot
);
else
{
/* if we run out of slots or we are not using tempool */
sprintf
(
table_name
,
"%s%lx_%lx_%x"
,
tmp_file_prefix
,
current_pid
,
sprintf
(
path
,
"%s%lx_%lx_%x"
,
tmp_file_prefix
,
current_pid
,
thd
->
thread_id
,
thd
->
tmp_table
++
);
}
...
...
@@ -9441,8 +9441,8 @@ create_tmp_table(THD *thd,TMP_TABLE_PARAM *param,List<Item> &fields,
No need to change table name to lower case as we are only creating
MyISAM or HEAP tables here
*/
fn_format
(
path
,
table_name
,
mysql_tmpdir
,
""
,
MY_REPLACE_EXT
|
MY_UNPACK_FILENAME
);
fn_format
(
path
,
path
,
mysql_tmpdir
,
""
,
MY_REPLACE_EXT
|
MY_UNPACK_FILENAME
);
if
(
group
)
{
...
...
@@ -9488,8 +9488,7 @@ create_tmp_table(THD *thd,TMP_TABLE_PARAM *param,List<Item> &fields,
sizeof
(
*
key_part_info
)
*
(
param
->
group_parts
+
1
),
&
param
->
start_recinfo
,
sizeof
(
*
param
->
recinfo
)
*
(
field_count
*
2
+
4
),
&
tmppath
,
(
uint
)
strlen
(
path
)
+
1
,
&
tmpname
,
(
uint
)
strlen
(
table_name
)
+
1
,
&
tmpname
,
(
uint
)
strlen
(
path
)
+
1
,
&
group_buff
,
(
group
&&
!
using_unique_constraint
?
param
->
group_length
:
0
),
&
bitmaps
,
bitmap_buffer_size
(
field_count
)
*
2
,
...
...
@@ -9508,8 +9507,7 @@ create_tmp_table(THD *thd,TMP_TABLE_PARAM *param,List<Item> &fields,
DBUG_RETURN
(
NULL
);
/* purecov: inspected */
}
param
->
items_to_copy
=
copy_func
;
strmov
(
tmppath
,
path
);
strmov
(
tmpname
,
table_name
);
strmov
(
tmpname
,
path
);
/* make table according to fields */
bzero
((
char
*
)
table
,
sizeof
(
*
table
));
...
...
@@ -9534,7 +9532,7 @@ create_tmp_table(THD *thd,TMP_TABLE_PARAM *param,List<Item> &fields,
table
->
keys_in_use_for_query
.
init
();
table
->
s
=
share
;
init_tmp_table_share
(
share
,
""
,
0
,
tmpname
,
tmp
path
);
init_tmp_table_share
(
share
,
""
,
0
,
tmpname
,
tmp
name
);
share
->
blob_field
=
blob_field
;
share
->
blob_ptr_size
=
mi_portable_sizeof_char_ptr
;
share
->
db_low_byte_first
=
1
;
// True for HEAP and MyISAM
...
...
sql/sql_view.cc
View file @
f5f65c40
...
...
@@ -397,9 +397,15 @@ bool mysql_create_view(THD *thd, TABLE_LIST *views,
{
Item_field
*
field
;
if
((
field
=
item
->
filed_for_view_update
()))
{
/*
any_privileges may be reset later by the Item_field::set_field
method in case of a system temporary table.
*/
field
->
any_privileges
=
1
;
}
}
}
#endif
if
(
open_and_lock_tables
(
thd
,
tables
))
...
...
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