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
b37a5568
Commit
b37a5568
authored
Jun 07, 2001
by
Sinisa@sinisa.nasamreza.org
Browse files
Options
Browse Files
Download
Plain Diff
bk resolve work
parents
e1d12383
62f56301
Changes
14
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
975 additions
and
248 deletions
+975
-248
BitKeeper/etc/logging_ok
BitKeeper/etc/logging_ok
+10
-0
sql/filesort.cc
sql/filesort.cc
+1
-1
sql/item.cc
sql/item.cc
+1
-1
sql/item_sum.cc
sql/item_sum.cc
+1
-1
sql/mysql_priv.h
sql/mysql_priv.h
+3
-3
sql/sql_class.h
sql/sql_class.h
+37
-8
sql/sql_delete.cc
sql/sql_delete.cc
+561
-2
sql/sql_lex.cc
sql/sql_lex.cc
+5
-5
sql/sql_lex.h
sql/sql_lex.h
+33
-16
sql/sql_parse.cc
sql/sql_parse.cc
+158
-87
sql/sql_select.cc
sql/sql_select.cc
+6
-6
sql/sql_update.cc
sql/sql_update.cc
+1
-1
sql/sql_yacc.yy
sql/sql_yacc.yy
+144
-108
sql/uniques.cc
sql/uniques.cc
+14
-9
No files found.
BitKeeper/etc/logging_ok
View file @
b37a5568
Sinisa@sinisa.nasamreza.org
heikki@donna.mysql.fi
heikki@donna.mysql.fi
jani@hynda.mysql.fi
jani@janikt.pp.saunalahti.fi
jani@janikt.pp.saunalahti.fi
jcole@abel.spaceapes.com
jcole@main.burghcom.com
jcole@tetra.spaceapes.com
monty@donna.mysql.fi
monty@hundin.mysql.fi
monty@hundin.mysql.fi
monty@tik.mysql.fi
monty@work.mysql.com
monty@work.mysql.com
mwagner@evoq.mwagner.org
mwagner@evoq.mwagner.org
paul@central.snake.net
paul@central.snake.net
paul@teton.kitebird.com
paul@teton.kitebird.com
root@x3.internalnet
sasha@mysql.sashanet.com
sasha@mysql.sashanet.com
serg@serg.mysql.com
serg@serg.mysql.com
tim@hundin.mysql.fi
tim@hundin.mysql.fi
tim@threads.polyesthetic.msg
tim@threads.polyesthetic.msg
tim@work.mysql.com
tonu@hundin.mysql.fi
tonu@hundin.mysql.fi
tonu@x3.internalnet
sql/filesort.cc
View file @
b37a5568
...
@@ -739,7 +739,7 @@ int merge_buffers(SORTPARAM *param, IO_CACHE *from_file,
...
@@ -739,7 +739,7 @@ int merge_buffers(SORTPARAM *param, IO_CACHE *from_file,
buffpek
=
(
BUFFPEK
*
)
queue_top
(
&
queue
);
buffpek
=
(
BUFFPEK
*
)
queue_top
(
&
queue
);
if
(
cmp
)
// Remove duplicates
if
(
cmp
)
// Remove duplicates
{
{
if
(
!
cmp
(
&
sort_length
,
param
->
unique_buff
,
(
uchar
*
)
buffpek
->
key
))
if
(
!
cmp
(
&
sort_length
,
&
(
param
->
unique_buff
),
(
uchar
**
)
&
buffpek
->
key
))
goto
skip_duplicate
;
goto
skip_duplicate
;
memcpy
(
param
->
unique_buff
,
(
uchar
*
)
buffpek
->
key
,
sort_length
);
memcpy
(
param
->
unique_buff
,
(
uchar
*
)
buffpek
->
key
,
sort_length
);
}
}
...
...
sql/item.cc
View file @
b37a5568
...
@@ -561,7 +561,7 @@ bool Item_ref::fix_fields(THD *thd,TABLE_LIST *tables)
...
@@ -561,7 +561,7 @@ bool Item_ref::fix_fields(THD *thd,TABLE_LIST *tables)
{
{
if
(
!
ref
)
if
(
!
ref
)
{
{
if
(
!
(
ref
=
find_item_in_list
(
this
,
thd
->
lex
.
item_list
)))
if
(
!
(
ref
=
find_item_in_list
(
this
,
thd
->
lex
.
select
->
item_list
)))
return
1
;
return
1
;
max_length
=
(
*
ref
)
->
max_length
;
max_length
=
(
*
ref
)
->
max_length
;
maybe_null
=
(
*
ref
)
->
maybe_null
;
maybe_null
=
(
*
ref
)
->
maybe_null
;
...
...
sql/item_sum.cc
View file @
b37a5568
...
@@ -884,7 +884,7 @@ bool Item_sum_count_distinct::setup(THD *thd)
...
@@ -884,7 +884,7 @@ bool Item_sum_count_distinct::setup(THD *thd)
tmp_table_param
->
cleanup
();
tmp_table_param
->
cleanup
();
}
}
if
(
!
(
table
=
create_tmp_table
(
thd
,
tmp_table_param
,
list
,
(
ORDER
*
)
0
,
1
,
if
(
!
(
table
=
create_tmp_table
(
thd
,
tmp_table_param
,
list
,
(
ORDER
*
)
0
,
1
,
0
,
0
,
current_lex
->
options
|
thd
->
options
)))
0
,
0
,
current_lex
->
select
->
options
|
thd
->
options
)))
return
1
;
return
1
;
table
->
file
->
extra
(
HA_EXTRA_NO_ROWS
);
// Don't update rows
table
->
file
->
extra
(
HA_EXTRA_NO_ROWS
);
// Don't update rows
table
->
no_rows
=
1
;
table
->
no_rows
=
1
;
...
...
sql/mysql_priv.h
View file @
b37a5568
...
@@ -667,7 +667,7 @@ extern int sql_cache_hit(THD *thd, char *inBuf, uint length);
...
@@ -667,7 +667,7 @@ extern int sql_cache_hit(THD *thd, char *inBuf, uint length);
inline
bool
add_item_to_list
(
Item
*
item
)
inline
bool
add_item_to_list
(
Item
*
item
)
{
{
return
current_lex
->
item_list
.
push_back
(
item
);
return
current_lex
->
select
->
item_list
.
push_back
(
item
);
}
}
inline
bool
add_value_to_list
(
Item
*
value
)
inline
bool
add_value_to_list
(
Item
*
value
)
{
{
...
@@ -675,11 +675,11 @@ inline bool add_value_to_list(Item *value)
...
@@ -675,11 +675,11 @@ inline bool add_value_to_list(Item *value)
}
}
inline
bool
add_order_to_list
(
Item
*
item
,
bool
asc
)
inline
bool
add_order_to_list
(
Item
*
item
,
bool
asc
)
{
{
return
add_to_list
(
current_lex
->
order_list
,
item
,
asc
);
return
add_to_list
(
current_lex
->
select
->
order_list
,
item
,
asc
);
}
}
inline
bool
add_group_to_list
(
Item
*
item
,
bool
asc
)
inline
bool
add_group_to_list
(
Item
*
item
,
bool
asc
)
{
{
return
add_to_list
(
current_lex
->
group_list
,
item
,
asc
);
return
add_to_list
(
current_lex
->
select
->
group_list
,
item
,
asc
);
}
}
inline
void
mark_as_null_row
(
TABLE
*
table
)
inline
void
mark_as_null_row
(
TABLE
*
table
)
{
{
...
...
sql/sql_class.h
View file @
b37a5568
...
@@ -464,8 +464,6 @@ public:
...
@@ -464,8 +464,6 @@ public:
void
send_error
(
uint
errcode
,
const
char
*
err
);
void
send_error
(
uint
errcode
,
const
char
*
err
);
bool
send_eof
();
bool
send_eof
();
};
};
class
select_insert
:
public
select_result
{
class
select_insert
:
public
select_result
{
protected:
protected:
TABLE
*
table
;
TABLE
*
table
;
...
@@ -578,19 +576,50 @@ class Unique :public Sql_alloc
...
@@ -578,19 +576,50 @@ class Unique :public Sql_alloc
public:
public:
ulong
elements
;
ulong
elements
;
Unique
(
qsort_cmp2
comp_func
,
uint
size
,
ulong
max_in_memory_size_arg
);
Unique
(
qsort_cmp2
comp_func
,
void
*
comp_func_fixed_arg
,
uint
size
,
ulong
max_in_memory_size_arg
);
~
Unique
();
~
Unique
();
inline
bool
Unique
::
unique_add
(
gptr
ptr
)
inline
bool
Unique
::
unique_add
(
gptr
ptr
)
{
{
if
(
tree
.
elements_in_tree
>
max_elements
&&
flush
())
if
(
tree
.
elements_in_tree
>
max_elements
&&
flush
())
return
1
;
return
1
;
return
tree_insert
(
&
tree
,
ptr
,
0
);
return
!
tree_insert
(
&
tree
,
ptr
,
0
);
}
}
bool
get
(
TABLE
*
table
);
bool
get
(
TABLE
*
table
);
friend
int
unique_write_to_file
(
gptr
key
,
Unique
*
unique
,
friend
int
unique_write_to_file
(
gptr
key
,
element_count
count
,
Unique
*
unique
);
element_count
count
);
friend
int
unique_write_to_ptrs
(
gptr
key
,
element_count
count
,
Unique
*
unique
);
friend
int
unique_write_to_ptrs
(
gptr
key
,
Unique
*
unique
,
element_count
count
);
};
};
class
multi_delete
:
public
select_result
{
TABLE_LIST
*
delete_tables
,
*
table_being_deleted
;
#ifdef SINISAS_STRIP
IO_CACHE
**
tempfiles
;
byte
*
memory_lane
;
#else
Unique
**
tempfiles
;
#endif
byte
*
dup_checking
;
THD
*
thd
;
ha_rows
deleted
;
int
num_of_tables
,
error
;
thr_lock_type
lock_option
;
bool
do_delete
;
public:
multi_delete
(
TABLE_LIST
*
dt
,
thr_lock_type
o
,
uint
n
)
:
delete_tables
(
dt
),
lock_option
(
o
),
deleted
(
0
),
num_of_tables
(
n
),
error
(
0
)
{
thd
=
current_thd
;
do_delete
=
false
;
}
~
multi_delete
();
int
prepare
(
List
<
Item
>
&
list
);
bool
send_fields
(
List
<
Item
>
&
list
,
uint
flag
)
{
return
0
;
}
bool
send_data
(
List
<
Item
>
&
items
);
void
send_error
(
uint
errcode
,
const
char
*
err
);
int
do_deletes
(
bool
from_send_error
);
bool
send_eof
();
};
sql/sql_delete.cc
View file @
b37a5568
This diff is collapsed.
Click to expand it.
sql/sql_lex.cc
View file @
b37a5568
...
@@ -142,11 +142,11 @@ LEX *lex_start(THD *thd, uchar *buf,uint length)
...
@@ -142,11 +142,11 @@ LEX *lex_start(THD *thd, uchar *buf,uint length)
lex
->
next_state
=
STATE_START
;
lex
->
next_state
=
STATE_START
;
lex
->
end_of_query
=
(
lex
->
ptr
=
buf
)
+
length
;
lex
->
end_of_query
=
(
lex
->
ptr
=
buf
)
+
length
;
lex
->
yylineno
=
1
;
lex
->
yylineno
=
1
;
lex
->
create_refs
=
lex
->
in_comment
=
0
;
lex
->
select
->
create_refs
=
lex
->
in_comment
=
0
;
lex
->
length
=
0
;
lex
->
length
=
0
;
lex
->
in_sum_expr
=
0
;
lex
->
select
->
in_sum_expr
=
0
;
lex
->
expr_list
.
empty
();
lex
->
select
->
expr_list
.
empty
();
lex
->
ftfunc_list
.
empty
();
lex
->
select
->
ftfunc_list
.
empty
();
lex
->
convert_set
=
(
lex
->
thd
=
thd
)
->
convert_set
;
lex
->
convert_set
=
(
lex
->
thd
=
thd
)
->
convert_set
;
lex
->
yacc_yyss
=
lex
->
yacc_yyvs
=
0
;
lex
->
yacc_yyss
=
lex
->
yacc_yyvs
=
0
;
lex
->
ignore_space
=
test
(
thd
->
client_capabilities
&
CLIENT_IGNORE_SPACE
);
lex
->
ignore_space
=
test
(
thd
->
client_capabilities
&
CLIENT_IGNORE_SPACE
);
...
@@ -155,7 +155,7 @@ LEX *lex_start(THD *thd, uchar *buf,uint length)
...
@@ -155,7 +155,7 @@ LEX *lex_start(THD *thd, uchar *buf,uint length)
void
lex_end
(
LEX
*
lex
)
void
lex_end
(
LEX
*
lex
)
{
{
lex
->
expr_list
.
delete_elements
();
// If error when parsing sql-varargs
lex
->
select
->
expr_list
.
delete_elements
();
// If error when parsing sql-varargs
x_free
(
lex
->
yacc_yyss
);
x_free
(
lex
->
yacc_yyss
);
x_free
(
lex
->
yacc_yyvs
);
x_free
(
lex
->
yacc_yyvs
);
}
}
...
...
sql/sql_lex.h
View file @
b37a5568
...
@@ -55,7 +55,7 @@ enum enum_sql_command {
...
@@ -55,7 +55,7 @@ enum enum_sql_command {
SQLCOM_RESET
,
SQLCOM_PURGE
,
SQLCOM_SHOW_BINLOGS
,
SQLCOM_RESET
,
SQLCOM_PURGE
,
SQLCOM_SHOW_BINLOGS
,
SQLCOM_SHOW_OPEN_TABLES
,
SQLCOM_LOAD_MASTER_DATA
,
SQLCOM_SHOW_OPEN_TABLES
,
SQLCOM_LOAD_MASTER_DATA
,
SQLCOM_HA_OPEN
,
SQLCOM_HA_CLOSE
,
SQLCOM_HA_READ
,
SQLCOM_HA_OPEN
,
SQLCOM_HA_CLOSE
,
SQLCOM_HA_READ
,
SQLCOM_SHOW_SLAVE_HOSTS
SQLCOM_SHOW_SLAVE_HOSTS
,
SQLCOM_MULTI_DELETE
};
};
enum
lex_states
{
STATE_START
,
STATE_CHAR
,
STATE_IDENT
,
enum
lex_states
{
STATE_START
,
STATE_CHAR
,
STATE_IDENT
,
...
@@ -95,39 +95,57 @@ typedef struct st_lex_master_info
...
@@ -95,39 +95,57 @@ typedef struct st_lex_master_info
ulonglong
pos
;
ulonglong
pos
;
}
LEX_MASTER_INFO
;
}
LEX_MASTER_INFO
;
enum
sub_select_type
{
UNSPECIFIED_TYPE
,
UNION_TYPE
,
INTERSECT_TYPE
,
EXCEPT_TYPE
};
/* The state of the lex parsing for selects */
typedef
struct
st_select_lex
{
enum
sub_select_type
linkage
;
uint
select_number
;
/* For Item_select */
char
*
db
,
*
db1
,
*
table1
,
*
db2
,
*
table2
;
/* For outer join using .. */
Item
*
where
,
*
having
;
ha_rows
select_limit
,
offset_limit
;
ulong
options
;
List
<
List_item
>
expr_list
;
List
<
List_item
>
when_list
;
SQL_LIST
order_list
,
table_list
,
group_list
;
List
<
Item
>
item_list
;
List
<
String
>
interval_list
,
use_index
,
*
use_index_ptr
,
ignore_index
,
*
ignore_index_ptr
;
List
<
Item_func_match
>
ftfunc_list
;
uint
in_sum_expr
,
sort_default
;
bool
create_refs
;
st_select_lex
*
next
;
}
SELECT_LEX
;
/* The state of the lex parsing. This is saved in the THD struct */
/* The state of the lex parsing. This is saved in the THD struct */
typedef
struct
st_lex
{
typedef
struct
st_lex
{
uint
yylineno
,
yytoklen
;
/* Simulate lex */
uint
yylineno
,
yytoklen
;
/* Simulate lex */
LEX_YYSTYPE
yylval
;
LEX_YYSTYPE
yylval
;
SELECT_LEX
select_lex
,
*
select
;
uchar
*
ptr
,
*
tok_start
,
*
tok_end
,
*
end_of_query
;
uchar
*
ptr
,
*
tok_start
,
*
tok_end
,
*
end_of_query
;
char
*
length
,
*
dec
,
*
change
,
*
name
;
char
*
length
,
*
dec
,
*
change
,
*
name
;
char
*
db
,
*
db1
,
*
table1
,
*
db2
,
*
table2
;
/* For outer join using .. */
char
*
backup_dir
;
/* For RESTORE/BACKUP */
char
*
backup_dir
;
/* For RESTORE/BACKUP */
char
*
to_log
;
/* For PURGE MASTER LOGS TO */
char
*
to_log
;
/* For PURGE MASTER LOGS TO */
String
*
wild
;
String
*
wild
;
sql_exchange
*
exchange
;
sql_exchange
*
exchange
;
ha_rows
select_limit
,
offset_limit
;
List
<
List_item
>
expr_list
;
List
<
List_item
>
when_list
;
List
<
List_item
>
many_values
;
List
<
key_part_spec
>
col_list
;
List
<
key_part_spec
>
col_list
;
List
<
Alter_drop
>
drop_list
;
List
<
Alter_drop
>
drop_list
;
List
<
Alter_column
>
alter_list
;
List
<
Alter_column
>
alter_list
;
List
<
String
>
interval_list
,
use_index
,
*
use_index_ptr
,
List
<
String
>
interval_list
;
ignore_index
,
*
ignore_index_ptr
;
List
<
st_lex_user
>
users_list
;
List
<
st_lex_user
>
users_list
;
List
<
LEX_COLUMN
>
columns
;
List
<
LEX_COLUMN
>
columns
;
List
<
Key
>
key_list
;
List
<
Key
>
key_list
;
List
<
create_field
>
create_list
;
List
<
create_field
>
create_list
;
List
<
Item
>
item_list
,
*
insert_list
,
field_list
,
value_list
;
List
<
Item
>
*
insert_list
,
field_list
,
value_list
;
List
<
Item_func_match
>
ftfunc_list
;
List
<
List_item
>
many_values
;
SQL_LIST
order_list
,
table_list
,
group_list
,
proc
_list
;
SQL_LIST
proc_list
,
auxilliary_table
_list
;
TYPELIB
*
interval
;
TYPELIB
*
interval
;
create_field
*
last_field
;
create_field
*
last_field
;
Item
*
default_value
;
Item
*
where
,
*
having
,
*
default_value
;
CONVERT
*
convert_set
;
CONVERT
*
convert_set
;
LEX_USER
*
grant_user
;
LEX_USER
*
grant_user
;
gptr
yacc_yyss
,
yacc_yyvs
;
gptr
yacc_yyss
,
yacc_yyvs
;
...
@@ -137,7 +155,6 @@ typedef struct st_lex {
...
@@ -137,7 +155,6 @@ typedef struct st_lex {
HA_CREATE_INFO
create_info
;
HA_CREATE_INFO
create_info
;
LEX_MASTER_INFO
mi
;
// used by CHANGE MASTER
LEX_MASTER_INFO
mi
;
// used by CHANGE MASTER
ulong
thread_id
,
type
;
ulong
thread_id
,
type
;
ulong
options
;
ulong
gemini_spin_retries
;
ulong
gemini_spin_retries
;
enum_sql_command
sql_command
;
enum_sql_command
sql_command
;
enum
lex_states
next_state
;
enum
lex_states
next_state
;
...
@@ -146,9 +163,9 @@ typedef struct st_lex {
...
@@ -146,9 +163,9 @@ typedef struct st_lex {
enum
enum_ha_read_modes
ha_read_mode
;
enum
enum_ha_read_modes
ha_read_mode
;
enum
ha_rkey_function
ha_rkey_mode
;
enum
ha_rkey_function
ha_rkey_mode
;
enum
enum_enable_or_disable
alter_keys_onoff
;
enum
enum_enable_or_disable
alter_keys_onoff
;
uint
in_sum_expr
,
grant
,
grant_tot_col
,
which_columns
,
sort_default
;
uint
grant
,
grant_tot_col
,
which_columns
;
thr_lock_type
lock_option
;
thr_lock_type
lock_option
;
bool
create_refs
,
drop_primary
,
drop_if_exists
,
local_file
;
bool
drop_primary
,
drop_if_exists
,
local_file
;
bool
in_comment
,
ignore_space
,
verbose
,
simple_alter
;
bool
in_comment
,
ignore_space
,
verbose
,
simple_alter
;
}
LEX
;
}
LEX
;
...
...
sql/sql_parse.cc
View file @
b37a5568
This diff is collapsed.
Click to expand it.
sql/sql_select.cc
View file @
b37a5568
...
@@ -2478,7 +2478,7 @@ make_join_readinfo(JOIN *join,uint options)
...
@@ -2478,7 +2478,7 @@ make_join_readinfo(JOIN *join,uint options)
/* These init changes read_record */
/* These init changes read_record */
if
(
tab
->
use_quick
==
2
)
if
(
tab
->
use_quick
==
2
)
{
{
join
->
thd
->
lex
.
options
|=
QUERY_NO_GOOD_INDEX_USED
;
join
->
thd
->
lex
.
select_lex
.
options
|=
QUERY_NO_GOOD_INDEX_USED
;
tab
->
read_first_record
=
join_init_quick_read_record
;
tab
->
read_first_record
=
join_init_quick_read_record
;
statistic_increment
(
select_range_check_count
,
&
LOCK_status
);
statistic_increment
(
select_range_check_count
,
&
LOCK_status
);
}
}
...
@@ -2493,7 +2493,7 @@ make_join_readinfo(JOIN *join,uint options)
...
@@ -2493,7 +2493,7 @@ make_join_readinfo(JOIN *join,uint options)
}
}
else
else
{
{
join
->
thd
->
lex
.
options
|=
QUERY_NO_INDEX_USED
;
join
->
thd
->
lex
.
select_lex
.
options
|=
QUERY_NO_INDEX_USED
;
statistic_increment
(
select_scan_count
,
&
LOCK_status
);
statistic_increment
(
select_scan_count
,
&
LOCK_status
);
}
}
}
}
...
@@ -2505,7 +2505,7 @@ make_join_readinfo(JOIN *join,uint options)
...
@@ -2505,7 +2505,7 @@ make_join_readinfo(JOIN *join,uint options)
}
}
else
else
{
{
join
->
thd
->
lex
.
options
|=
QUERY_NO_INDEX_USED
;
join
->
thd
->
lex
.
select_lex
.
options
|=
QUERY_NO_INDEX_USED
;
statistic_increment
(
select_full_join_count
,
&
LOCK_status
);
statistic_increment
(
select_full_join_count
,
&
LOCK_status
);
}
}
}
}
...
@@ -3920,7 +3920,7 @@ bool create_myisam_from_heap(TABLE *table, TMP_TABLE_PARAM *param, int error,
...
@@ -3920,7 +3920,7 @@ bool create_myisam_from_heap(TABLE *table, TMP_TABLE_PARAM *param, int error,
thd
->
proc_info
=
"converting HEAP to MyISAM"
;
thd
->
proc_info
=
"converting HEAP to MyISAM"
;
if
(
create_myisam_tmp_table
(
&
new_table
,
param
,
if
(
create_myisam_tmp_table
(
&
new_table
,
param
,
thd
->
lex
.
options
|
thd
->
options
))
thd
->
lex
.
select_lex
.
options
|
thd
->
options
))
goto
err2
;
goto
err2
;
if
(
open_tmp_table
(
&
new_table
))
if
(
open_tmp_table
(
&
new_table
))
goto
err1
;
goto
err1
;
...
@@ -6647,7 +6647,7 @@ static void select_describe(JOIN *join, bool need_tmp_table, bool need_order,
...
@@ -6647,7 +6647,7 @@ static void select_describe(JOIN *join, bool need_tmp_table, bool need_order,
DBUG_ENTER
(
"select_describe"
);
DBUG_ENTER
(
"select_describe"
);
/* Don't log this into the slow query log */
/* Don't log this into the slow query log */
join
->
thd
->
lex
.
options
&=
~
(
QUERY_NO_INDEX_USED
|
QUERY_NO_GOOD_INDEX_USED
);
join
->
thd
->
lex
.
select_lex
.
options
&=
~
(
QUERY_NO_INDEX_USED
|
QUERY_NO_GOOD_INDEX_USED
);
field_list
.
push_back
(
new
Item_empty_string
(
"table"
,
NAME_LEN
));
field_list
.
push_back
(
new
Item_empty_string
(
"table"
,
NAME_LEN
));
field_list
.
push_back
(
new
Item_empty_string
(
"type"
,
10
));
field_list
.
push_back
(
new
Item_empty_string
(
"type"
,
10
));
field_list
.
push_back
(
item
=
new
Item_empty_string
(
"possible_keys"
,
field_list
.
push_back
(
item
=
new
Item_empty_string
(
"possible_keys"
,
...
@@ -6806,7 +6806,7 @@ static void describe_info(THD *thd, const char *info)
...
@@ -6806,7 +6806,7 @@ static void describe_info(THD *thd, const char *info)
String
*
packet
=
&
thd
->
packet
;
String
*
packet
=
&
thd
->
packet
;
/* Don't log this into the slow query log */
/* Don't log this into the slow query log */
thd
->
lex
.
options
&=
~
(
QUERY_NO_INDEX_USED
|
QUERY_NO_GOOD_INDEX_USED
);
thd
->
lex
.
select_lex
.
options
&=
~
(
QUERY_NO_INDEX_USED
|
QUERY_NO_GOOD_INDEX_USED
);
field_list
.
push_back
(
new
Item_empty_string
(
"Comment"
,
80
));
field_list
.
push_back
(
new
Item_empty_string
(
"Comment"
,
80
));
if
(
send_fields
(
thd
,
field_list
,
1
))
if
(
send_fields
(
thd
,
field_list
,
1
))
return
;
/* purecov: inspected */
return
;
/* purecov: inspected */
...
...
sql/sql_update.cc
View file @
b37a5568
...
@@ -128,7 +128,7 @@ int mysql_update(THD *thd,
...
@@ -128,7 +128,7 @@ int mysql_update(THD *thd,
/* If running in safe sql mode, don't allow updates without keys */
/* If running in safe sql mode, don't allow updates without keys */
if
(
!
table
->
quick_keys
)
if
(
!
table
->
quick_keys
)
{
{
thd
->
lex
.
options
|=
QUERY_NO_INDEX_USED
;
thd
->
lex
.
select_lex
.
options
|=
QUERY_NO_INDEX_USED
;
if
((
thd
->
options
&
OPTION_SAFE_UPDATES
)
&&
limit
==
HA_POS_ERROR
)
if
((
thd
->
options
&
OPTION_SAFE_UPDATES
)
&&
limit
==
HA_POS_ERROR
)
{
{
delete
select
;
delete
select
;
...
...
sql/sql_yacc.yy
View file @
b37a5568
This diff is collapsed.
Click to expand it.
sql/uniques.cc
View file @
b37a5568
...
@@ -34,14 +34,17 @@
...
@@ -34,14 +34,17 @@
#include "mysql_priv.h"
#include "mysql_priv.h"
#include "sql_sort.h"
#include "sql_sort.h"
Unique
::
Unique
(
qsort_cmp2
comp_func
,
uint
size
,
ulong
max_in_memory_size_arg
)
Unique
::
Unique
(
qsort_cmp2
comp_func
,
void
*
comp_func_fixed_arg
,
uint
size
,
ulong
max_in_memory_size_arg
)
:
max_in_memory_size
(
max_in_memory_size_arg
),
elements
(
0
)
:
max_in_memory_size
(
max_in_memory_size_arg
),
elements
(
0
)
{
{
my_b_clear
(
&
file
);
init_tree
(
&
tree
,
max_in_memory_size
/
16
,
size
,
comp_func
,
0
,
0
);
init_tree
(
&
tree
,
max_in_memory_size
/
16
,
size
,
comp_func
,
0
,
0
);
tree
.
cmp_arg
=
comp_func_fixed_arg
;
/* If the following fail's the next add will also fail */
/* If the following fail's the next add will also fail */
init_dynamic_array
(
&
file_ptrs
,
sizeof
(
BUFFPEK
),
16
,
16
);
init_dynamic_array
(
&
file_ptrs
,
sizeof
(
BUFFPEK
),
16
,
16
);
max_elements
=
max_in_memory_size
/
ALIGN_SIZE
(
sizeof
(
TREE_ELEMENT
)
+
size
);
max_elements
=
max_in_memory_size
/
ALIGN_SIZE
(
sizeof
(
TREE_ELEMENT
)
+
size
);
open_cached_file
(
&
file
,
mysql_tmpdir
,
TEMP_PREFIX
,
DISK_BUFFER_SIZE
,
MYF
(
MY_WME
));
}
}
...
@@ -69,12 +72,12 @@ bool Unique::flush()
...
@@ -69,12 +72,12 @@ bool Unique::flush()
}
}
int
unique_write_to_file
(
gptr
key
,
Unique
*
unique
,
element_count
count
)
int
unique_write_to_file
(
gptr
key
,
element_count
count
,
Unique
*
unique
)
{
{
return
my_b_write
(
&
unique
->
file
,
key
,
unique
->
tree
.
size_of_element
)
?
1
:
0
;
return
my_b_write
(
&
unique
->
file
,
key
,
unique
->
tree
.
size_of_element
)
?
1
:
0
;
}
}
int
unique_write_to_ptrs
(
gptr
key
,
Unique
*
unique
,
element_count
count
)
int
unique_write_to_ptrs
(
gptr
key
,
element_count
count
,
Unique
*
unique
)
{
{
memcpy
(
unique
->
record_pointers
,
key
,
unique
->
tree
.
size_of_element
);
memcpy
(
unique
->
record_pointers
,
key
,
unique
->
tree
.
size_of_element
);
unique
->
record_pointers
+=
unique
->
tree
.
size_of_element
;
unique
->
record_pointers
+=
unique
->
tree
.
size_of_element
;
...
@@ -109,7 +112,7 @@ bool Unique::get(TABLE *table)
...
@@ -109,7 +112,7 @@ bool Unique::get(TABLE *table)
IO_CACHE
*
outfile
=
table
->
io_cache
,
tempfile
;
IO_CACHE
*
outfile
=
table
->
io_cache
,
tempfile
;
BUFFPEK
*
file_ptr
=
(
BUFFPEK
*
)
file_ptrs
.
buffer
;
BUFFPEK
*
file_ptr
=
(
BUFFPEK
*
)
file_ptrs
.
buffer
;
uint
maxbuffer
=
file_ptrs
.
elements
;
uint
maxbuffer
=
file_ptrs
.
elements
-
1
;
uchar
*
sort_buffer
;
uchar
*
sort_buffer
;
my_off_t
save_pos
;
my_off_t
save_pos
;
bool
error
=
1
;
bool
error
=
1
;
...
@@ -117,18 +120,20 @@ bool Unique::get(TABLE *table)
...
@@ -117,18 +120,20 @@ bool Unique::get(TABLE *table)
my_b_clear
(
&
tempfile
);
my_b_clear
(
&
tempfile
);
/* Open cached file if it isn't open */
/* Open cached file if it isn't open */
if
(
!
my_b_inited
(
outfile
)
&&
outfile
=
table
->
io_cache
=
(
IO_CACHE
*
)
my_malloc
(
sizeof
(
IO_CACHE
),
MYF
(
MY_ZEROFILL
));
if
(
!
outfile
||
!
my_b_inited
(
outfile
)
&&
open_cached_file
(
outfile
,
mysql_tmpdir
,
TEMP_PREFIX
,
READ_RECORD_BUFFER
,
open_cached_file
(
outfile
,
mysql_tmpdir
,
TEMP_PREFIX
,
READ_RECORD_BUFFER
,
MYF
(
MY_WME
)))
MYF
(
MY_WME
)))
return
1
;
return
1
;
reinit_io_cache
(
outfile
,
WRITE_CACHE
,
0L
,
0
,
0
);
reinit_io_cache
(
outfile
,
WRITE_CACHE
,
0L
,
0
,
0
);
sort_param
.
keys
=
elements
;
sort_param
.
max_rows
=
elements
;
sort_param
.
sort_form
=
table
;
sort_param
.
sort_form
=
table
;
sort_param
.
sort_length
=
sort_param
.
ref_length
=
tree
.
size_of_element
;
sort_param
.
sort_length
=
sort_param
.
ref_length
=
tree
.
size_of_element
;
sort_param
.
keys
=
max_in_memory_size
/
sort_param
.
sort_length
;
sort_param
.
keys
=
max_in_memory_size
/
sort_param
.
sort_length
;
if
(
!
(
sort_buffer
=
(
uchar
*
)
my_malloc
((
sort_param
.
keys
+
1
)
*
if
(
!
(
sort_buffer
=
(
uchar
*
)
my_malloc
((
sort_param
.
keys
+
1
)
*
sort_param
.
sort_length
,
sort_param
.
sort_length
,
MYF
(
0
))))
MYF
(
0
))))
return
1
;
return
1
;
...
...
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