61
48
nearly-identical class Field_date doesn't ever return 3 from its
64
int Field_date::store(const char *from,
66
const CHARSET_INFO * const )
69
* Try to create a DateTime from the supplied string. Throw an error
70
* if unable to create a valid DateTime. A DateTime is used so that
71
* automatic conversion from the higher-storage DateTime can be used
72
* and matches on datetime format strings can occur.
74
ASSERT_COLUMN_MARKED_FOR_WRITE;
76
if (! temporal.from_string(from, (size_t) len))
78
my_error(ER_INVALID_DATE_VALUE, MYF(ME_FATALERROR), from);
81
/* Create the stored integer format. @TODO This should go away. Should be up to engine... */
82
uint32_t int_value= (temporal.years() * 10000) + (temporal.months() * 100) + temporal.days();
83
int4store(ptr, int_value);
87
int Field_date::store(double from)
89
ASSERT_COLUMN_MARKED_FOR_WRITE;
90
if (from < 0.0 || from > 99991231235959.0)
92
/* Convert the double to a string using stringstream */
95
ss.precision(18); /* 18 places should be fine for error display of double input. */
96
ss << from; ss >> tmp;
98
my_error(ER_INVALID_DATE_VALUE, MYF(ME_FATALERROR), tmp.c_str());
101
return Field_date::store((int64_t) rint(from), false);
104
int Field_date::store(int64_t from, bool)
107
* Try to create a DateTime from the supplied integer. Throw an error
108
* if unable to create a valid DateTime.
110
ASSERT_COLUMN_MARKED_FOR_WRITE;
112
if (! temporal.from_int64_t(from))
114
/* Convert the integer to a string using boost::lexical_cast */
115
std::string tmp(boost::lexical_cast<std::string>(from));
117
my_error(ER_INVALID_DATE_VALUE, MYF(ME_FATALERROR), tmp.c_str());
121
/* Create the stored integer format. @TODO This should go away. Should be up to engine... */
122
uint32_t int_value= (temporal.years() * 10000) + (temporal.months() * 100) + temporal.days();
123
int4store(ptr, int_value);
128
int Field_date::store_time(type::Time <ime,
129
type::timestamp_t time_type)
52
int Field_newdate::store(const char *from,
54
CHARSET_INFO *cs __attribute__((__unused__)))
59
THD *thd= table ? table->in_use : current_thd;
60
enum enum_mysql_timestamp_type ret;
61
if ((ret= str_to_datetime(from, len, &l_time,
63
(thd->variables.sql_mode &
64
(MODE_NO_ZERO_IN_DATE | MODE_NO_ZERO_DATE |
65
MODE_INVALID_DATES))),
66
&error)) <= MYSQL_TIMESTAMP_ERROR)
73
tmp= l_time.day + l_time.month*32 + l_time.year*16*32;
74
if (!error && (ret != MYSQL_TIMESTAMP_DATE) &&
75
(l_time.hour || l_time.minute || l_time.second || l_time.second_part))
76
error= 3; // Datetime was cut (note)
80
set_datetime_warning(error == 3 ? MYSQL_ERROR::WARN_LEVEL_NOTE :
81
MYSQL_ERROR::WARN_LEVEL_WARN,
83
from, len, MYSQL_TIMESTAMP_DATE, 1);
90
int Field_newdate::store(double nr)
92
if (nr < 0.0 || nr > 99991231235959.0)
94
int3store(ptr,(int32) 0);
95
set_datetime_warning(MYSQL_ERROR::WARN_LEVEL_WARN,
96
WARN_DATA_TRUNCATED, nr, MYSQL_TIMESTAMP_DATE);
99
return Field_newdate::store((int64_t) rint(nr), false);
103
int Field_newdate::store(int64_t nr,
104
bool unsigned_val __attribute__((__unused__)))
109
THD *thd= table ? table->in_use : current_thd;
110
if (number_to_datetime(nr, &l_time,
112
(thd->variables.sql_mode &
113
(MODE_NO_ZERO_IN_DATE | MODE_NO_ZERO_DATE |
114
MODE_INVALID_DATES))),
121
tmp= l_time.day + l_time.month*32 + l_time.year*16*32;
123
if (!error && l_time.time_type != MYSQL_TIMESTAMP_DATE &&
124
(l_time.hour || l_time.minute || l_time.second || l_time.second_part))
128
set_datetime_warning(error == 3 ? MYSQL_ERROR::WARN_LEVEL_NOTE :
129
MYSQL_ERROR::WARN_LEVEL_WARN,
131
ER_WARN_DATA_OUT_OF_RANGE : WARN_DATA_TRUNCATED,
132
nr,MYSQL_TIMESTAMP_DATE, 1);
139
int Field_newdate::store_time(MYSQL_TIME *ltime,timestamp_type time_type)
133
if (time_type == type::DRIZZLE_TIMESTAMP_DATE || time_type == type::DRIZZLE_TIMESTAMP_DATETIME)
143
if (time_type == MYSQL_TIMESTAMP_DATE ||
144
time_type == MYSQL_TIMESTAMP_DATETIME)
135
tmp= ltime.year*10000 + ltime.month*100 + ltime.day;
137
Session *session= getTable() ? getTable()->in_use : current_session;
138
type::cut_t cut_error= type::VALID;
139
if (ltime.check(tmp != 0,
141
(session->variables.sql_mode & (MODE_NO_ZERO_DATE | MODE_INVALID_DATES))), cut_error))
146
tmp=ltime->year*16*32+ltime->month*32+ltime->day;
147
if (check_date(ltime, tmp != 0,
149
(current_thd->variables.sql_mode &
150
(MODE_NO_ZERO_IN_DATE | MODE_NO_ZERO_DATE |
151
MODE_INVALID_DATES))), &error))
143
char buff[type::Time::MAX_STRING_LENGTH];
144
String str(buff, sizeof(buff), &my_charset_utf8_general_ci);
145
ltime.convert(str, type::DRIZZLE_TIMESTAMP_DATE);
146
set_datetime_warning(DRIZZLE_ERROR::WARN_LEVEL_WARN, ER_WARN_DATA_TRUNCATED,
147
str.ptr(), str.length(), type::DRIZZLE_TIMESTAMP_DATE, 1);
153
char buff[MAX_DATE_STRING_REP_LENGTH];
154
String str(buff, sizeof(buff), &my_charset_latin1);
155
make_date((DATE_TIME_FORMAT *) 0, ltime, &str);
156
set_datetime_warning(MYSQL_ERROR::WARN_LEVEL_WARN, WARN_DATA_TRUNCATED,
157
str.ptr(), str.length(), MYSQL_TIMESTAMP_DATE, 1);
150
error= static_cast<int>(cut_error);
152
if (not error && ltime.time_type != type::DRIZZLE_TIMESTAMP_DATE &&
153
(ltime.hour || ltime.minute || ltime.second || ltime.second_part))
159
if (!error && ltime->time_type != MYSQL_TIMESTAMP_DATE &&
160
(ltime->hour || ltime->minute || ltime->second || ltime->second_part))
155
char buff[type::Time::MAX_STRING_LENGTH];
156
String str(buff, sizeof(buff), &my_charset_utf8_general_ci);
158
set_datetime_warning(DRIZZLE_ERROR::WARN_LEVEL_NOTE,
159
ER_WARN_DATA_TRUNCATED,
160
str.ptr(), str.length(), type::DRIZZLE_TIMESTAMP_DATE, 1);
162
char buff[MAX_DATE_STRING_REP_LENGTH];
163
String str(buff, sizeof(buff), &my_charset_latin1);
164
make_datetime((DATE_TIME_FORMAT *) 0, ltime, &str);
165
set_datetime_warning(MYSQL_ERROR::WARN_LEVEL_NOTE,
167
str.ptr(), str.length(), MYSQL_TIMESTAMP_DATE, 1);
168
set_warning(DRIZZLE_ERROR::WARN_LEVEL_WARN, ER_WARN_DATA_TRUNCATED, 1);
175
set_warning(MYSQL_ERROR::WARN_LEVEL_WARN, WARN_DATA_TRUNCATED, 1);
176
double Field_date::val_real(void) const
178
return (double) Field_date::val_int();
181
int64_t Field_date::val_int(void) const
185
ASSERT_COLUMN_MARKED_FOR_READ;
182
bool Field_newdate::send_binary(Protocol *protocol)
185
Field_newdate::get_date(&tm,0);
186
return protocol->store_date(&tm);
190
double Field_newdate::val_real(void)
192
return (double) Field_newdate::val_int();
196
int64_t Field_newdate::val_int(void)
198
ulong j= uint3korr(ptr);
199
j= (j % 32L)+(j / 32L % 16L)*100L + (j/(16L*32L))*10000L;
189
200
return (int64_t) j;
192
String *Field_date::val_str(String *val_buffer, String *) const
204
String *Field_newdate::val_str(String *val_buffer,
205
String *val_ptr __attribute__((unused)))
194
207
val_buffer->alloc(field_length);
195
208
val_buffer->length(field_length);
196
uint32_t tmp=(uint32_t) uint4korr(ptr);
209
uint32 tmp=(uint32) uint3korr(ptr);
198
211
char *pos=(char*) val_buffer->ptr()+10;
200
ASSERT_COLUMN_MARKED_FOR_READ;
202
213
/* Open coded to get more speed */
203
214
*pos--=0; // End NULL
204
part=(int32_t) (tmp % 100);
205
*pos--= (char) ('0'+part%10);
206
*pos--= (char) ('0'+part/10);
208
part=(int32_t) (tmp/100%100);
209
*pos--= (char) ('0'+part%10);
210
*pos--= (char) ('0'+part/10);
212
part=(int32_t) (tmp/10000);
215
part=(int) (tmp & 31);
216
*pos--= (char) ('0'+part%10);
217
*pos--= (char) ('0'+part/10);
219
part=(int) (tmp >> 5 & 15);
220
*pos--= (char) ('0'+part%10);
221
*pos--= (char) ('0'+part/10);
223
part=(int) (tmp >> 9);
213
224
*pos--= (char) ('0'+part%10); part/=10;
214
225
*pos--= (char) ('0'+part%10); part/=10;
215
226
*pos--= (char) ('0'+part%10); part/=10;
217
228
return val_buffer;
220
bool Field_date::get_date(type::Time <ime, uint32_t fuzzydate) const
232
bool Field_newdate::get_date(MYSQL_TIME *ltime,uint fuzzydate)
222
uint32_t tmp=(uint32_t) uint4korr(ptr);
223
ltime.day= (int) (tmp%100);
224
ltime.month= (int) (tmp/100%100);
225
ltime.year= (int) (tmp/10000);
226
ltime.time_type= type::DRIZZLE_TIMESTAMP_DATE;
227
ltime.hour= ltime.minute= ltime.second= ltime.second_part= ltime.neg= 0;
229
return ((!(fuzzydate & TIME_FUZZY_DATE) && (!ltime.month || !ltime.day)) ?
234
uint32 tmp=(uint32) uint3korr(ptr);
235
ltime->day= tmp & 31;
236
ltime->month= (tmp >> 5) & 15;
237
ltime->year= (tmp >> 9);
238
ltime->time_type= MYSQL_TIMESTAMP_DATE;
239
ltime->hour= ltime->minute= ltime->second= ltime->second_part= ltime->neg= 0;
240
return ((!(fuzzydate & TIME_FUZZY_DATE) && (!ltime->month || !ltime->day)) ?
233
bool Field_date::get_time(type::Time <ime) const
245
bool Field_newdate::get_time(MYSQL_TIME *ltime)
235
return Field_date::get_date(ltime ,0);
247
return Field_newdate::get_date(ltime,0);
238
int Field_date::cmp(const unsigned char *a_ptr, const unsigned char *b_ptr)
251
int Field_newdate::cmp(const uchar *a_ptr, const uchar *b_ptr)
241
a=(uint32_t) uint4korr(a_ptr);
242
b=(uint32_t) uint4korr(b_ptr);
254
a=(uint32) uint3korr(a_ptr);
255
b=(uint32) uint3korr(b_ptr);
243
256
return (a < b) ? -1 : (a > b) ? 1 : 0;
246
void Field_date::sort_string(unsigned char *to,uint32_t )
260
void Field_newdate::sort_string(uchar *to,uint length __attribute__((unused)))
254
void Field_date::sql_type(String &res) const
268
void Field_newdate::sql_type(String &res) const
256
270
res.set_ascii(STRING_WITH_LEN("date"));
259
} /* namespace drizzled */