79
73
tmp= l_time.day + l_time.month*32 + l_time.year*16*32;
80
if (!error && (ret != DRIZZLE_TIMESTAMP_DATE) &&
74
if (!error && (ret != MYSQL_TIMESTAMP_DATE) &&
81
75
(l_time.hour || l_time.minute || l_time.second || l_time.second_part))
82
76
error= 3; // Datetime was cut (note)
86
set_datetime_warning(error == 3 ? DRIZZLE_ERROR::WARN_LEVEL_NOTE :
87
DRIZZLE_ERROR::WARN_LEVEL_WARN,
88
ER_WARN_DATA_TRUNCATED,
89
from, len, DRIZZLE_TIMESTAMP_DATE, 1);
80
set_datetime_warning(error == 3 ? MYSQL_ERROR::WARN_LEVEL_NOTE :
81
MYSQL_ERROR::WARN_LEVEL_WARN,
83
from, len, MYSQL_TIMESTAMP_DATE, 1);
91
85
int3store(ptr, tmp);
92
#endif /* NOTDEFINED */
94
* Try to create a DateTime from the supplied string. Throw an error
95
* if unable to create a valid DateTime. A DateTime is used so that
96
* automatic conversion from the higher-storage DateTime can be used
97
* and matches on datetime format strings can occur.
99
ASSERT_COLUMN_MARKED_FOR_WRITE;
100
drizzled::DateTime temporal;
101
if (! temporal.from_string(from, (size_t) len))
103
my_error(ER_INVALID_DATETIME_VALUE, MYF(ME_FATALERROR), from);
106
/* Create the stored integer format. @TODO This should go away. Should be up to engine... */
107
uint32_t int_value= (temporal.years() * 16 * 32) + (temporal.months() * 32) + temporal.days();
108
int3store(ptr, int_value);
112
int Field_date::store(double from)
114
ASSERT_COLUMN_MARKED_FOR_WRITE;
115
if (from < 0.0 || from > 99991231235959.0)
117
/* Convert the double to a string using stringstream */
118
std::stringstream ss;
120
ss.precision(18); /* 18 places should be fine for error display of double input. */
121
ss << from; ss >> tmp;
123
my_error(ER_INVALID_DATETIME_VALUE, MYF(ME_FATALERROR), tmp.c_str());
126
return Field_date::store((int64_t) rint(from), false);
129
int Field_date::store(int64_t from, bool)
132
* Try to create a DateTime from the supplied integer. Throw an error
133
* if unable to create a valid DateTime.
135
ASSERT_COLUMN_MARKED_FOR_WRITE;
136
drizzled::DateTime temporal;
137
if (! temporal.from_int64_t(from))
139
/* Convert the integer to a string using stringstream */
140
std::stringstream ss;
142
ss << from; ss >> tmp;
144
my_error(ER_INVALID_DATETIME_VALUE, MYF(ME_FATALERROR), tmp.c_str());
148
/* Create the stored integer format. @TODO This should go away. Should be up to engine... */
149
uint32_t int_value= (temporal.years() * 16 * 32) + (temporal.months() * 32) + temporal.days();
150
int3store(ptr, int_value);
154
int Field_date::store_time(DRIZZLE_TIME *ltime,
155
enum enum_drizzle_timestamp_type time_type)
90
int Field_newdate::store(double nr)
92
if (nr < 0.0 || nr > 99991231235959.0)
94
int3store(ptr,(int32_t) 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)
159
if (time_type == DRIZZLE_TIMESTAMP_DATE ||
160
time_type == DRIZZLE_TIMESTAMP_DATETIME)
143
if (time_type == MYSQL_TIMESTAMP_DATE ||
144
time_type == MYSQL_TIMESTAMP_DATETIME)
162
146
tmp=ltime->year*16*32+ltime->month*32+ltime->day;
163
147
if (check_date(ltime, tmp != 0,
164
148
(TIME_FUZZY_DATE |
165
(current_session->variables.sql_mode &
166
(MODE_NO_ZERO_DATE | MODE_INVALID_DATES))), &error))
149
(current_thd->variables.sql_mode &
150
(MODE_NO_ZERO_IN_DATE | MODE_NO_ZERO_DATE |
151
MODE_INVALID_DATES))), &error))
168
153
char buff[MAX_DATE_STRING_REP_LENGTH];
169
String str(buff, sizeof(buff), &my_charset_utf8_general_ci);
170
make_date(ltime, &str);
171
set_datetime_warning(DRIZZLE_ERROR::WARN_LEVEL_WARN, ER_WARN_DATA_TRUNCATED,
172
str.ptr(), str.length(), DRIZZLE_TIMESTAMP_DATE, 1);
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);
174
if (!error && ltime->time_type != DRIZZLE_TIMESTAMP_DATE &&
159
if (!error && ltime->time_type != MYSQL_TIMESTAMP_DATE &&
175
160
(ltime->hour || ltime->minute || ltime->second || ltime->second_part))
177
162
char buff[MAX_DATE_STRING_REP_LENGTH];
178
String str(buff, sizeof(buff), &my_charset_utf8_general_ci);
179
make_datetime(ltime, &str);
180
set_datetime_warning(DRIZZLE_ERROR::WARN_LEVEL_NOTE,
181
ER_WARN_DATA_TRUNCATED,
182
str.ptr(), str.length(), DRIZZLE_TIMESTAMP_DATE, 1);
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);