Details
-
Task
-
Status: Closed (View Workflow)
-
Major
-
Resolution: Fixed
-
None
Description
These methods:
longlong Item_func_between::val_int_cmp_temporal()
|
char *in_temporal::get_value_internal() |
void cmp_item_temporal::store_value_internal() |
use val_temporal_packed(field_type()) internally.
This is not friendly to new data types, e.g. it won't work for a new implementation for TIMESTAMP (needed for MDEV-15654) which transfers TIMESTAMP data inside the server using my_time_t representation rather than MYSQL_TIME representation.
This task is to remove Item::val_temporal_packed() and split implementations of the mentioned methods into separate methods for TIME and DATETIME:
longlong Item_func_between::val_int_cmp_time()
|
longlong Item_func_between::val_int_cmp_datetime()
|
uchar *in_datetime::get_value()
|
uchar *in_time::get_value()
|
void cmp_item_datetime::store_value() |
void cmp_item_time::store_value() |
These methods will use val_time_packed() and val_datetime_packed() directly.
Attachments
Issue Links
- blocks
-
MDEV-4912 Data type plugin API version 1
-
- Closed
-
Activity
Description |
These methods:
{code:cpp} longlong Item_func_between::val_int_cmp_temporal() char *in_temporal::get_value_internal() void cmp_item_temporal::store_value_internal() {code} use val_temporal_packed(field_type()) internally. This is not friendly to new data types, e.g. it won't work for a new implementation for TIMESTAMP (needed for This task is to remove {{Item::val_temporal_packed()}} and split implementations of the mentioned methods into separate methods for TIME and DATETIME: {code:cpp} longlong Item_func_between::val_int_cmp_time() longlong Item_func_between::val_int_cmp_datetime() uchar *in_datetime::get_value() uchar *in_time::get_value() void cmp_item_datetime::store_value() void cmp_item_time::store_value() {code} These methods will use {{val_time_packed()}} and {{val_datetime_packed()}} directly. |
These methods:
{code:cpp} longlong Item_func_between::val_int_cmp_temporal() char *in_temporal::get_value_internal() void cmp_item_temporal::store_value_internal() {code} use {{val_temporal_packed(field_type())}} internally. This is not friendly to new data types, e.g. it won't work for a new implementation for TIMESTAMP (needed for This task is to remove {{Item::val_temporal_packed()}} and split implementations of the mentioned methods into separate methods for TIME and DATETIME: {code:cpp} longlong Item_func_between::val_int_cmp_time() longlong Item_func_between::val_int_cmp_datetime() uchar *in_datetime::get_value() uchar *in_time::get_value() void cmp_item_datetime::store_value() void cmp_item_time::store_value() {code} These methods will use {{val_time_packed()}} and {{val_datetime_packed()}} directly. |
Fix Version/s | 10.4.0 [ 23115 ] | |
Fix Version/s | 10.4 [ 22408 ] | |
Resolution | Fixed [ 1 ] | |
Status | Open [ 1 ] | Closed [ 6 ] |
Workflow | MariaDB v3 [ 87772 ] | MariaDB v4 [ 133600 ] |