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
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
dcaba14f
Commit
dcaba14f
authored
Sep 28, 2004
by
konstantin@mysql.com
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Give store_for_compare a more meaningful name, cleanup and comment the
call.
parent
c3fdbf0f
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
18 additions
and
11 deletions
+18
-11
sql/field.h
sql/field.h
+15
-8
sql/item_cmpfunc.cc
sql/item_cmpfunc.cc
+3
-3
No files found.
sql/field.h
View file @
dcaba14f
...
...
@@ -179,7 +179,14 @@ class Field
virtual
void
make_field
(
Send_field
*
)
=
0
;
virtual
void
sort_string
(
char
*
buff
,
uint
length
)
=
0
;
virtual
bool
optimize_range
(
uint
idx
,
uint
part
);
virtual
bool
store_for_compare
()
{
return
0
;
}
/*
This should be true for fields which, when compared with constant
items, can be casted to longlong. In this case we will at 'fix_fields'
stage cast the constant items to longlongs and at the execution stage
use field->val_int() for comparison. Used to optimize clauses like
'a_column BETWEEN date_const, date_const'.
*/
virtual
bool
can_be_compared_as_longlong
()
const
{
return
FALSE
;
}
virtual
void
free
()
{}
Field
*
new_field
(
MEM_ROOT
*
root
,
struct
st_table
*
new_table
)
{
...
...
@@ -566,7 +573,7 @@ class Field_longlong :public Field_num {
void
sort_string
(
char
*
buff
,
uint
length
);
uint32
pack_length
()
const
{
return
8
;
}
void
sql_type
(
String
&
str
)
const
;
bool
store_for_compare
()
{
return
1
;
}
bool
can_be_compared_as_longlong
()
const
{
return
TRUE
;
}
uint32
max_length
()
{
return
20
;
}
field_cast_enum
field_cast_type
()
{
return
FIELD_CAST_LONGLONG
;
}
};
...
...
@@ -694,7 +701,7 @@ class Field_timestamp :public Field_str {
void
sort_string
(
char
*
buff
,
uint
length
);
uint32
pack_length
()
const
{
return
4
;
}
void
sql_type
(
String
&
str
)
const
;
bool
store_for_compare
()
{
return
1
;
}
bool
can_be_compared_as_longlong
()
const
{
return
TRUE
;
}
bool
zero_pack
()
const
{
return
0
;
}
void
set_time
();
virtual
void
set_default
()
...
...
@@ -740,7 +747,7 @@ class Field_year :public Field_tiny {
String
*
val_str
(
String
*
,
String
*
);
bool
send_binary
(
Protocol
*
protocol
);
void
sql_type
(
String
&
str
)
const
;
bool
store_for_compare
()
{
return
1
;
}
bool
can_be_compared_as_longlong
()
const
{
return
TRUE
;
}
field_cast_enum
field_cast_type
()
{
return
FIELD_CAST_YEAR
;
}
};
...
...
@@ -772,7 +779,7 @@ class Field_date :public Field_str {
void
sort_string
(
char
*
buff
,
uint
length
);
uint32
pack_length
()
const
{
return
4
;
}
void
sql_type
(
String
&
str
)
const
;
bool
store_for_compare
()
{
return
1
;
}
bool
can_be_compared_as_longlong
()
const
{
return
TRUE
;
}
bool
zero_pack
()
const
{
return
1
;
}
field_cast_enum
field_cast_type
()
{
return
FIELD_CAST_DATE
;
}
};
...
...
@@ -802,7 +809,7 @@ class Field_newdate :public Field_str {
void
sort_string
(
char
*
buff
,
uint
length
);
uint32
pack_length
()
const
{
return
3
;
}
void
sql_type
(
String
&
str
)
const
;
bool
store_for_compare
()
{
return
1
;
}
bool
can_be_compared_as_longlong
()
const
{
return
TRUE
;
}
bool
zero_pack
()
const
{
return
1
;
}
bool
get_date
(
TIME
*
ltime
,
uint
fuzzydate
);
bool
get_time
(
TIME
*
ltime
);
...
...
@@ -839,7 +846,7 @@ class Field_time :public Field_str {
void
sort_string
(
char
*
buff
,
uint
length
);
uint32
pack_length
()
const
{
return
3
;
}
void
sql_type
(
String
&
str
)
const
;
bool
store_for_compare
()
{
return
1
;
}
bool
can_be_compared_as_longlong
()
const
{
return
TRUE
;
}
bool
zero_pack
()
const
{
return
1
;
}
field_cast_enum
field_cast_type
()
{
return
FIELD_CAST_TIME
;
}
};
...
...
@@ -875,7 +882,7 @@ class Field_datetime :public Field_str {
void
sort_string
(
char
*
buff
,
uint
length
);
uint32
pack_length
()
const
{
return
8
;
}
void
sql_type
(
String
&
str
)
const
;
bool
store_for_compare
()
{
return
1
;
}
bool
can_be_compared_as_longlong
()
const
{
return
TRUE
;
}
bool
zero_pack
()
const
{
return
1
;
}
bool
get_date
(
TIME
*
ltime
,
uint
fuzzydate
);
bool
get_time
(
TIME
*
ltime
);
...
...
sql/item_cmpfunc.cc
View file @
dcaba14f
...
...
@@ -243,7 +243,7 @@ void Item_bool_func2::fix_length_and_dec()
if
(
args
[
0
]
->
type
()
==
FIELD_ITEM
)
{
Field
*
field
=
((
Item_field
*
)
args
[
0
])
->
field
;
if
(
field
->
store_for_compare
())
if
(
field
->
can_be_compared_as_longlong
())
{
if
(
convert_constant_item
(
field
,
&
args
[
1
]))
{
...
...
@@ -256,7 +256,7 @@ void Item_bool_func2::fix_length_and_dec()
if
(
args
[
1
]
->
type
()
==
FIELD_ITEM
)
{
Field
*
field
=
((
Item_field
*
)
args
[
1
])
->
field
;
if
(
field
->
store_for_compare
())
if
(
field
->
can_be_compared_as_longlong
())
{
if
(
convert_constant_item
(
field
,
&
args
[
0
]))
{
...
...
@@ -856,7 +856,7 @@ void Item_func_between::fix_length_and_dec()
if
(
args
[
0
]
->
type
()
==
FIELD_ITEM
)
{
Field
*
field
=
((
Item_field
*
)
args
[
0
])
->
field
;
if
(
field
->
store_for_compare
())
if
(
field
->
can_be_compared_as_longlong
())
{
if
(
convert_constant_item
(
field
,
&
args
[
1
]))
cmp_type
=
INT_RESULT
;
// Works for all types.
...
...
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