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
5f8f947f
Commit
5f8f947f
authored
May 25, 2005
by
monty@mysql.com
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Cleanup's during review
Added ASSERT() to detect wrongly packed fields
parent
8832f3e1
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
41 additions
and
40 deletions
+41
-40
sql/field.h
sql/field.h
+6
-4
sql/opt_range.cc
sql/opt_range.cc
+19
-21
sql/sql_base.cc
sql/sql_base.cc
+2
-2
sql/sql_insert.cc
sql/sql_insert.cc
+4
-3
sql/sql_select.cc
sql/sql_select.cc
+4
-7
sql/unireg.cc
sql/unireg.cc
+6
-3
No files found.
sql/field.h
View file @
5f8f947f
...
@@ -439,10 +439,12 @@ public:
...
@@ -439,10 +439,12 @@ public:
/* The maximum number of decimal digits can be stored */
/* The maximum number of decimal digits can be stored */
uint
precision
;
uint
precision
;
uint
bin_size
;
uint
bin_size
;
/* Constructors take max_length of the field as a parameter - not the */
/*
/* precision as the number of decimal digits allowed */
Constructors take max_length of the field as a parameter - not the
/* So for example we need to count length from precision handling */
precision as the number of decimal digits allowed.
/* CREATE TABLE ( DECIMAL(x,y)) */
So for example we need to count length from precision handling
CREATE TABLE ( DECIMAL(x,y))
*/
Field_new_decimal
(
char
*
ptr_arg
,
uint32
len_arg
,
uchar
*
null_ptr_arg
,
Field_new_decimal
(
char
*
ptr_arg
,
uint32
len_arg
,
uchar
*
null_ptr_arg
,
uchar
null_bit_arg
,
uchar
null_bit_arg
,
enum
utype
unireg_check_arg
,
const
char
*
field_name_arg
,
enum
utype
unireg_check_arg
,
const
char
*
field_name_arg
,
...
...
sql/opt_range.cc
View file @
5f8f947f
...
@@ -3307,32 +3307,35 @@ QUICK_SELECT_I *TRP_ROR_UNION::make_quick(PARAM *param,
...
@@ -3307,32 +3307,35 @@ QUICK_SELECT_I *TRP_ROR_UNION::make_quick(PARAM *param,
/*
/*
Build a SEL_TREE for <> predicate
Build a SEL_TREE for <>
or NOT BETWEEN
predicate
SYNOPSIS
SYNOPSIS
get_ne_mm_tree()
get_ne_mm_tree()
param PARAM from SQL_SELECT::test_quick_select
param PARAM from SQL_SELECT::test_quick_select
cond_func item for the predicate
cond_func item for the predicate
field field in the predicate
field field in the predicate
value constant in the predicate
lt_value constant that field should be smaller
gt_value constant that field should be greaterr
cmp_type compare type for the field
cmp_type compare type for the field
RETURN
RETURN
Pointer to tree built tree
# Pointer to tree built tree
0 on error
*/
*/
static
SEL_TREE
*
get_ne_mm_tree
(
PARAM
*
param
,
Item_func
*
cond_func
,
static
SEL_TREE
*
get_ne_mm_tree
(
PARAM
*
param
,
Item_func
*
cond_func
,
Field
*
field
,
Item
*
value
,
Field
*
field
,
Item
*
lt_value
,
Item
*
gt_value
,
Item_result
cmp_type
)
Item_result
cmp_type
)
{
{
SEL_TREE
*
tree
=
0
;
SEL_TREE
*
tree
;
tree
=
get_mm_parts
(
param
,
cond_func
,
field
,
Item_func
::
LT_FUNC
,
tree
=
get_mm_parts
(
param
,
cond_func
,
field
,
Item_func
::
LT_FUNC
,
value
,
cmp_type
);
lt_
value
,
cmp_type
);
if
(
tree
)
if
(
tree
)
{
{
tree
=
tree_or
(
param
,
tree
,
get_mm_parts
(
param
,
cond_func
,
field
,
tree
=
tree_or
(
param
,
tree
,
get_mm_parts
(
param
,
cond_func
,
field
,
Item_func
::
GT_FUNC
,
Item_func
::
GT_FUNC
,
value
,
cmp_type
));
gt_
value
,
cmp_type
));
}
}
return
tree
;
return
tree
;
}
}
...
@@ -3365,21 +3368,14 @@ static SEL_TREE *get_func_mm_tree(PARAM *param, Item_func *cond_func,
...
@@ -3365,21 +3368,14 @@ static SEL_TREE *get_func_mm_tree(PARAM *param, Item_func *cond_func,
switch
(
cond_func
->
functype
())
{
switch
(
cond_func
->
functype
())
{
case
Item_func
:
:
NE_FUNC
:
case
Item_func
:
:
NE_FUNC
:
tree
=
get_ne_mm_tree
(
param
,
cond_func
,
field
,
value
,
cmp_type
);
tree
=
get_ne_mm_tree
(
param
,
cond_func
,
field
,
value
,
value
,
cmp_type
);
break
;
break
;
case
Item_func
:
:
BETWEEN
:
case
Item_func
:
:
BETWEEN
:
if
(
inv
)
if
(
inv
)
{
{
tree
=
get_mm_parts
(
param
,
cond_func
,
field
,
Item_func
::
LT_FUNC
,
tree
=
get_ne_mm_tree
(
param
,
cond_func
,
field
,
cond_func
->
arguments
()[
1
],
cond_func
->
arguments
()[
1
],
cmp_type
);
cond_func
->
arguments
()[
2
],
cmp_type
);
if
(
tree
)
{
tree
=
tree_or
(
param
,
tree
,
get_mm_parts
(
param
,
cond_func
,
field
,
Item_func
::
GT_FUNC
,
cond_func
->
arguments
()[
2
],
cmp_type
));
}
}
}
else
else
{
{
...
@@ -3402,7 +3398,8 @@ static SEL_TREE *get_func_mm_tree(PARAM *param, Item_func *cond_func,
...
@@ -3402,7 +3398,8 @@ static SEL_TREE *get_func_mm_tree(PARAM *param, Item_func *cond_func,
if
(
inv
)
if
(
inv
)
{
{
tree
=
get_ne_mm_tree
(
param
,
cond_func
,
field
,
tree
=
get_ne_mm_tree
(
param
,
cond_func
,
field
,
func
->
arguments
()[
1
],
cmp_type
);
func
->
arguments
()[
1
],
func
->
arguments
()[
1
],
cmp_type
);
if
(
tree
)
if
(
tree
)
{
{
Item
**
arg
,
**
end
;
Item
**
arg
,
**
end
;
...
@@ -3410,7 +3407,7 @@ static SEL_TREE *get_func_mm_tree(PARAM *param, Item_func *cond_func,
...
@@ -3410,7 +3407,7 @@ static SEL_TREE *get_func_mm_tree(PARAM *param, Item_func *cond_func,
arg
<
end
;
arg
++
)
arg
<
end
;
arg
++
)
{
{
tree
=
tree_and
(
param
,
tree
,
get_ne_mm_tree
(
param
,
cond_func
,
field
,
tree
=
tree_and
(
param
,
tree
,
get_ne_mm_tree
(
param
,
cond_func
,
field
,
*
arg
,
cmp_type
));
*
arg
,
*
arg
,
cmp_type
));
}
}
}
}
}
}
...
@@ -3523,6 +3520,7 @@ static SEL_TREE *get_mm_tree(PARAM *param,COND *cond)
...
@@ -3523,6 +3520,7 @@ static SEL_TREE *get_mm_tree(PARAM *param,COND *cond)
Item_func
*
cond_func
=
(
Item_func
*
)
cond
;
Item_func
*
cond_func
=
(
Item_func
*
)
cond
;
if
(
cond_func
->
functype
()
==
Item_func
::
NOT_FUNC
)
if
(
cond_func
->
functype
()
==
Item_func
::
NOT_FUNC
)
{
{
/* Optimize NOT BETWEEN and NOT IN */
Item
*
arg
=
cond_func
->
arguments
()[
0
];
Item
*
arg
=
cond_func
->
arguments
()[
0
];
if
(
arg
->
type
()
==
Item
::
FUNC_ITEM
)
if
(
arg
->
type
()
==
Item
::
FUNC_ITEM
)
{
{
...
...
sql/sql_base.cc
View file @
5f8f947f
sql/sql_insert.cc
View file @
5f8f947f
...
@@ -872,7 +872,8 @@ int write_record(THD *thd, TABLE *table,COPY_INFO *info)
...
@@ -872,7 +872,8 @@ int write_record(THD *thd, TABLE *table,COPY_INFO *info)
if
(
info
->
handle_duplicates
==
DUP_UPDATE
)
if
(
info
->
handle_duplicates
==
DUP_UPDATE
)
{
{
int
res
=
0
;
int
res
=
0
;
/* we don't check for other UNIQUE keys - the first row
/*
We don't check for other UNIQUE keys - the first row
that matches, is updated. If update causes a conflict again,
that matches, is updated. If update causes a conflict again,
an error is returned
an error is returned
*/
*/
...
...
sql/sql_select.cc
View file @
5f8f947f
...
@@ -2832,12 +2832,9 @@ add_key_fields(KEY_FIELD **key_fields,uint *and_level,
...
@@ -2832,12 +2832,9 @@ add_key_fields(KEY_FIELD **key_fields,uint *and_level,
*/
*/
if
(
item
->
type
()
==
Item
::
FUNC_ITEM
&&
if
(
item
->
type
()
==
Item
::
FUNC_ITEM
&&
((
Item_func
*
)
item
)
->
select_optimize
()
==
Item_func
::
OPTIMIZE_KEY
)
((
Item_func
*
)
item
)
->
select_optimize
()
==
Item_func
::
OPTIMIZE_KEY
)
{
add_key_fields
(
key_fields
,
and_level
,
item
,
usable_tables
);
add_key_fields
(
key_fields
,
and_level
,
item
,
usable_tables
);
return
;
return
;
}
}
return
;
}
switch
(
cond_func
->
select_optimize
())
{
switch
(
cond_func
->
select_optimize
())
{
case
Item_func
:
:
OPTIMIZE_NONE
:
case
Item_func
:
:
OPTIMIZE_NONE
:
break
;
break
;
...
...
sql/unireg.cc
View file @
5f8f947f
...
@@ -73,6 +73,7 @@ bool mysql_create_frm(THD *thd, my_string file_name,
...
@@ -73,6 +73,7 @@ bool mysql_create_frm(THD *thd, my_string file_name,
handler
*
db_file
)
handler
*
db_file
)
{
{
uint
reclength
,
info_length
,
screens
,
key_info_length
,
maxlength
;
uint
reclength
,
info_length
,
screens
,
key_info_length
,
maxlength
;
ulong
key_buff_length
;
File
file
;
File
file
;
ulong
filepos
,
data_offset
;
ulong
filepos
,
data_offset
;
uchar
fileinfo
[
64
],
forminfo
[
288
],
*
keybuff
;
uchar
fileinfo
[
64
],
forminfo
[
288
],
*
keybuff
;
...
@@ -119,7 +120,7 @@ bool mysql_create_frm(THD *thd, my_string file_name,
...
@@ -119,7 +120,7 @@ bool mysql_create_frm(THD *thd, my_string file_name,
DBUG_RETURN
(
1
);
DBUG_RETURN
(
1
);
}
}
uint
key_buff_length
=
keys
*
(
7
+
NAME_LEN
+
MAX_REF_PARTS
*
9
)
+
16
;
key_buff_length
=
uint4korr
(
fileinfo
+
47
)
;
keybuff
=
(
uchar
*
)
my_malloc
(
key_buff_length
,
MYF
(
0
));
keybuff
=
(
uchar
*
)
my_malloc
(
key_buff_length
,
MYF
(
0
));
key_info_length
=
pack_keys
(
keybuff
,
keys
,
key_info
,
data_offset
);
key_info_length
=
pack_keys
(
keybuff
,
keys
,
key_info
,
data_offset
);
VOID
(
get_form_pos
(
file
,
fileinfo
,
&
formnames
));
VOID
(
get_form_pos
(
file
,
fileinfo
,
&
formnames
));
...
@@ -128,7 +129,6 @@ bool mysql_create_frm(THD *thd, my_string file_name,
...
@@ -128,7 +129,6 @@ bool mysql_create_frm(THD *thd, my_string file_name,
maxlength
=
(
uint
)
next_io_size
((
ulong
)
(
uint2korr
(
forminfo
)
+
1000
));
maxlength
=
(
uint
)
next_io_size
((
ulong
)
(
uint2korr
(
forminfo
)
+
1000
));
int2store
(
forminfo
+
2
,
maxlength
);
int2store
(
forminfo
+
2
,
maxlength
);
int4store
(
fileinfo
+
10
,(
ulong
)
(
filepos
+
maxlength
));
int4store
(
fileinfo
+
10
,(
ulong
)
(
filepos
+
maxlength
));
int4store
(
fileinfo
+
47
,
key_buff_length
);
fileinfo
[
26
]
=
(
uchar
)
test
((
create_info
->
max_rows
==
1
)
&&
fileinfo
[
26
]
=
(
uchar
)
test
((
create_info
->
max_rows
==
1
)
&&
(
create_info
->
min_rows
==
1
)
&&
(
keys
==
0
));
(
create_info
->
min_rows
==
1
)
&&
(
keys
==
0
));
int2store
(
fileinfo
+
28
,
key_info_length
);
int2store
(
fileinfo
+
28
,
key_info_length
);
...
@@ -411,7 +411,8 @@ static bool pack_header(uchar *forminfo, enum db_type table_type,
...
@@ -411,7 +411,8 @@ static bool pack_header(uchar *forminfo, enum db_type table_type,
DBUG_RETURN
(
1
);
DBUG_RETURN
(
1
);
}
}
totlength
=
reclength
=
0L
;
totlength
=
0L
;
reclength
=
data_offset
;
no_empty
=
int_count
=
int_parts
=
int_length
=
time_stamp_pos
=
null_fields
=
no_empty
=
int_count
=
int_parts
=
int_length
=
time_stamp_pos
=
null_fields
=
com_length
=
0
;
com_length
=
0
;
n_length
=
2L
;
n_length
=
2L
;
...
@@ -440,6 +441,8 @@ static bool pack_header(uchar *forminfo, enum db_type table_type,
...
@@ -440,6 +441,8 @@ static bool pack_header(uchar *forminfo, enum db_type table_type,
!
time_stamp_pos
)
!
time_stamp_pos
)
time_stamp_pos
=
(
uint
)
field
->
offset
+
(
uint
)
data_offset
+
1
;
time_stamp_pos
=
(
uint
)
field
->
offset
+
(
uint
)
data_offset
+
1
;
length
=
field
->
pack_length
;
length
=
field
->
pack_length
;
/* Ensure we don't have any bugs when generating offsets */
DBUG_ASSERT
(
reclength
==
field
->
offset
+
data_offset
);
if
((
uint
)
field
->
offset
+
(
uint
)
data_offset
+
length
>
reclength
)
if
((
uint
)
field
->
offset
+
(
uint
)
data_offset
+
length
>
reclength
)
reclength
=
(
uint
)
(
field
->
offset
+
data_offset
+
length
);
reclength
=
(
uint
)
(
field
->
offset
+
data_offset
+
length
);
n_length
+=
(
ulong
)
strlen
(
field
->
field_name
)
+
1
;
n_length
+=
(
ulong
)
strlen
(
field
->
field_name
)
+
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