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
284479c0
Commit
284479c0
authored
Jun 04, 2014
by
Alexander Barkov
Browse files
Options
Browse Files
Download
Plain Diff
Merge 5.3->5.5
parents
55bfabf9
661daf16
Changes
24
Hide whitespace changes
Inline
Side-by-side
Showing
24 changed files
with
220 additions
and
75 deletions
+220
-75
include/my_global.h
include/my_global.h
+1
-0
include/my_time.h
include/my_time.h
+8
-1
mysql-test/r/cast.result
mysql-test/r/cast.result
+8
-8
mysql-test/r/dyncol.result
mysql-test/r/dyncol.result
+21
-10
mysql-test/r/func_time.result
mysql-test/r/func_time.result
+10
-2
mysql-test/r/type_datetime.result
mysql-test/r/type_datetime.result
+9
-0
mysql-test/r/type_time.result
mysql-test/r/type_time.result
+28
-0
mysql-test/r/type_time_hires.result
mysql-test/r/type_time_hires.result
+7
-7
mysql-test/suite/funcs_1/r/innodb_func_view.result
mysql-test/suite/funcs_1/r/innodb_func_view.result
+8
-8
mysql-test/suite/funcs_1/r/memory_func_view.result
mysql-test/suite/funcs_1/r/memory_func_view.result
+8
-8
mysql-test/suite/funcs_1/r/myisam_func_view.result
mysql-test/suite/funcs_1/r/myisam_func_view.result
+8
-8
mysql-test/t/dyncol.test
mysql-test/t/dyncol.test
+7
-0
mysql-test/t/func_time.test
mysql-test/t/func_time.test
+5
-0
mysql-test/t/type_datetime.test
mysql-test/t/type_datetime.test
+8
-0
mysql-test/t/type_time.test
mysql-test/t/type_time.test
+17
-0
sql-common/my_time.c
sql-common/my_time.c
+8
-4
sql/field.cc
sql/field.cc
+21
-6
sql/item.cc
sql/item.cc
+3
-1
sql/item_func.cc
sql/item_func.cc
+3
-1
sql/item_strfunc.cc
sql/item_strfunc.cc
+4
-2
sql/item_timefunc.cc
sql/item_timefunc.cc
+12
-0
sql/sql_error.h
sql/sql_error.h
+8
-3
sql/sql_time.cc
sql/sql_time.cc
+7
-5
sql/sql_time.h
sql/sql_time.h
+1
-1
No files found.
include/my_global.h
View file @
284479c0
...
@@ -483,6 +483,7 @@ typedef unsigned short ushort;
...
@@ -483,6 +483,7 @@ typedef unsigned short ushort;
#define swap_variables(t, a, b) { t dummy; dummy= a; a= b; b= dummy; }
#define swap_variables(t, a, b) { t dummy; dummy= a; a= b; b= dummy; }
#define test(a) ((a) ? 1 : 0)
#define test(a) ((a) ? 1 : 0)
#define MY_TEST(a) ((a) ? 1 : 0)
#define set_if_bigger(a,b) do { if ((a) < (b)) (a)=(b); } while(0)
#define set_if_bigger(a,b) do { if ((a) < (b)) (a)=(b); } while(0)
#define set_if_smaller(a,b) do { if ((a) > (b)) (a)=(b); } while(0)
#define set_if_smaller(a,b) do { if ((a) > (b)) (a)=(b); } while(0)
#define set_bits(type, bit_count) (sizeof(type)*8 <= (bit_count) ? ~(type) 0 : ((((type) 1) << (bit_count)) - (type) 1))
#define set_bits(type, bit_count) (sizeof(type)*8 <= (bit_count) ? ~(type) 0 : ((((type) 1) << (bit_count)) - (type) 1))
...
...
include/my_time.h
View file @
284479c0
...
@@ -79,6 +79,13 @@ typedef long my_time_t;
...
@@ -79,6 +79,13 @@ typedef long my_time_t;
#define MYSQL_TIME_WARN_TRUNCATED 1
#define MYSQL_TIME_WARN_TRUNCATED 1
#define MYSQL_TIME_WARN_OUT_OF_RANGE 2
#define MYSQL_TIME_WARN_OUT_OF_RANGE 2
#define MYSQL_TIME_NOTE_TRUNCATED 16
#define MYSQL_TIME_WARN_WARNINGS (MYSQL_TIME_WARN_TRUNCATED|MYSQL_TIME_WARN_OUT_OF_RANGE)
#define MYSQL_TIME_WARN_NOTES (MYSQL_TIME_NOTE_TRUNCATED)
#define MYSQL_TIME_WARN_HAVE_WARNINGS(x) MY_TEST((x) & MYSQL_TIME_WARN_WARNINGS)
#define MYSQL_TIME_WARN_HAVE_NOTES(x) MY_TEST((x) & MYSQL_TIME_WARN_NOTES)
/* Limits for the TIME data type */
/* Limits for the TIME data type */
#define TIME_MAX_HOUR 838
#define TIME_MAX_HOUR 838
...
@@ -112,7 +119,7 @@ longlong double_to_datetime(double nr, MYSQL_TIME *ltime, uint flags, int *cut)
...
@@ -112,7 +119,7 @@ longlong double_to_datetime(double nr, MYSQL_TIME *ltime, uint flags, int *cut)
ltime
,
flags
,
cut
);
ltime
,
flags
,
cut
);
}
}
int
number_to_time
(
my_bool
neg
,
longlong
nr
,
ulong
sec_part
,
int
number_to_time
(
my_bool
neg
,
u
longlong
nr
,
ulong
sec_part
,
MYSQL_TIME
*
ltime
,
int
*
was_cut
);
MYSQL_TIME
*
ltime
,
int
*
was_cut
);
ulonglong
TIME_to_ulonglong_datetime
(
const
MYSQL_TIME
*
);
ulonglong
TIME_to_ulonglong_datetime
(
const
MYSQL_TIME
*
);
ulonglong
TIME_to_ulonglong_date
(
const
MYSQL_TIME
*
);
ulonglong
TIME_to_ulonglong_date
(
const
MYSQL_TIME
*
);
...
...
mysql-test/r/cast.result
View file @
284479c0
No preview for this file type
mysql-test/r/dyncol.result
View file @
284479c0
...
@@ -1001,29 +1001,29 @@ Warnings:
...
@@ -1001,29 +1001,29 @@ Warnings:
Warning 1292 Truncated incorrect time value: '1223.5aa'
Warning 1292 Truncated incorrect time value: '1223.5aa'
select column_get(column_create(1, 18446744073709551615 AS unsigned int), 1 as time);
select column_get(column_create(1, 18446744073709551615 AS unsigned int), 1 as time);
column_get(column_create(1, 18446744073709551615 AS unsigned int), 1 as time)
column_get(column_create(1, 18446744073709551615 AS unsigned int), 1 as time)
NULL
838:59:59
Warnings:
Warnings:
Warning 1292
Incorrect date
time value: '1.8446744073709552e19'
Warning 1292
Truncated incorrect
time value: '1.8446744073709552e19'
select column_get(column_create(1, 9223372036854775807 AS int), 1 as time);
select column_get(column_create(1, 9223372036854775807 AS int), 1 as time);
column_get(column_create(1, 9223372036854775807 AS int), 1 as time)
column_get(column_create(1, 9223372036854775807 AS int), 1 as time)
NULL
838:59:59
Warnings:
Warnings:
Warning 1292
Incorrect date
time value: '9223372036854775807'
Warning 1292
Truncated incorrect
time value: '9223372036854775807'
select column_get(column_create(1, -9223372036854775808 AS int), 1 as time);
select column_get(column_create(1, -9223372036854775808 AS int), 1 as time);
column_get(column_create(1, -9223372036854775808 AS int), 1 as time)
column_get(column_create(1, -9223372036854775808 AS int), 1 as time)
NULL
-838:59:59
Warnings:
Warnings:
Warning 1292
Incorrect date
time value: '-9223372036854775808'
Warning 1292
Truncated incorrect
time value: '-9223372036854775808'
select column_get(column_create(1, 99999999999999999999999999999 AS decimal(32,10)), 1 as time);
select column_get(column_create(1, 99999999999999999999999999999 AS decimal(32,10)), 1 as time);
column_get(column_create(1, 99999999999999999999999999999 AS decimal(32,10)), 1 as time)
column_get(column_create(1, 99999999999999999999999999999 AS decimal(32,10)), 1 as time)
NULL
838:59:59
Warnings:
Warnings:
Warning 1292
Incorrect date
time value: '99999999999999999999999999999'
Warning 1292
Truncated incorrect
time value: '99999999999999999999999999999'
select column_get(column_create(1, 99999999999999999999999999999 AS double), 1 as time);
select column_get(column_create(1, 99999999999999999999999999999 AS double), 1 as time);
column_get(column_create(1, 99999999999999999999999999999 AS double), 1 as time)
column_get(column_create(1, 99999999999999999999999999999 AS double), 1 as time)
NULL
838:59:59
Warnings:
Warnings:
Warning 1292
Incorrect date
time value: '1e29'
Warning 1292
Truncated incorrect
time value: '1e29'
select column_get(column_create(1, "2011-02-32 8:46:06.23434" AS CHAR), 1 as time);
select column_get(column_create(1, "2011-02-32 8:46:06.23434" AS CHAR), 1 as time);
column_get(column_create(1, "2011-02-32 8:46:06.23434" AS CHAR), 1 as time)
column_get(column_create(1, "2011-02-32 8:46:06.23434" AS CHAR), 1 as time)
NULL
NULL
...
@@ -1425,6 +1425,17 @@ Warning 1265 Data truncated for column 'dyncol' at row 1
...
@@ -1425,6 +1425,17 @@ Warning 1265 Data truncated for column 'dyncol' at row 1
SELECT COLUMN_ADD( dyncol, 7, '22:22:22', 8, REPEAT('x',270) AS CHAR ) FROM t1;
SELECT COLUMN_ADD( dyncol, 7, '22:22:22', 8, REPEAT('x',270) AS CHAR ) FROM t1;
DROP table t1;
DROP table t1;
#
#
# MDEV-4858 Wrong results for a huge unsigned value inserted into a TIME column
#
SELECT
column_get(column_create(1, -999999999999999 AS int), 1 AS TIME) AS t1,
column_get(column_create(1, -9223372036854775808 AS int), 1 AS TIME) AS t2;
t1 t2
-838:59:59 -838:59:59
Warnings:
Warning 1292 Truncated incorrect time value: '-999999999999999'
Warning 1292 Truncated incorrect time value: '-9223372036854775808'
#
# end of 5.3 tests
# end of 5.3 tests
#
#
select column_get(column_create(1, "18446744073709552001" as char), 1 as int);
select column_get(column_create(1, "18446744073709552001" as char), 1 as int);
...
...
mysql-test/r/func_time.result
View file @
284479c0
...
@@ -1091,9 +1091,9 @@ NULL
...
@@ -1091,9 +1091,9 @@ NULL
select isnull(week(now() + 0)), isnull(week(now() + 0.2)),
select isnull(week(now() + 0)), isnull(week(now() + 0.2)),
week(20061108), week(20061108.01), week(20061108085411.000002);
week(20061108), week(20061108.01), week(20061108085411.000002);
isnull(week(now() + 0)) isnull(week(now() + 0.2)) week(20061108) week(20061108.01) week(20061108085411.000002)
isnull(week(now() + 0)) isnull(week(now() + 0.2)) week(20061108) week(20061108.01) week(20061108085411.000002)
0 0 45
NULL
45
0 0 45
45
45
Warnings:
Warnings:
Warning 1292
I
ncorrect datetime value: '20061108.01'
Warning 1292
Truncated i
ncorrect datetime value: '20061108.01'
End of 4.1 tests
End of 4.1 tests
select time_format('100:00:00', '%H %k %h %I %l');
select time_format('100:00:00', '%H %k %h %I %l');
time_format('100:00:00', '%H %k %h %I %l')
time_format('100:00:00', '%H %k %h %I %l')
...
@@ -2408,3 +2408,11 @@ SELECT 1 FROM t1 GROUP BY MONTHNAME(0) WITH ROLLUP;
...
@@ -2408,3 +2408,11 @@ SELECT 1 FROM t1 GROUP BY MONTHNAME(0) WITH ROLLUP;
1
1
1
1
DROP TABLE t1;
DROP TABLE t1;
#
# MDEV-6099 Bad results for DATE_ADD(.., INTERVAL 2000000000000000000.0 SECOND)
#
SELECT DATE_ADD('2001-01-01 10:20:30',INTERVAL 250000000000.0 SECOND) AS c1, DATE_ADD('2001-01-01 10:20:30',INTERVAL 2000000000000000000.0 SECOND) AS c2;
c1 c2
9923-03-10 22:47:10.0 NULL
Warnings:
Warning 1292 Truncated incorrect DECIMAL value: '2000000000000000000.0'
mysql-test/r/type_datetime.result
View file @
284479c0
...
@@ -724,6 +724,15 @@ call test5041();
...
@@ -724,6 +724,15 @@ call test5041();
dt
dt
0000-01-02 08:20:30
0000-01-02 08:20:30
drop procedure test5041;
drop procedure test5041;
#
# MDEV-6097 Inconsistent results for CAST(int,decimal,double AS DATETIME)
#
SELECT
CAST(010203101112 AS DATETIME(1)) AS c1,
CAST(010203101112.2 AS DATETIME(1)) AS c2,
CAST(010203101112.2+0e0 AS DATETIME(1)) AS c3;
c1 c2 c3
2001-02-03 10:11:12.0 2001-02-03 10:11:12.2 2001-02-03 10:11:12.2
End of 5.3 tests
End of 5.3 tests
#
#
# Start of 5.5 tests
# Start of 5.5 tests
...
...
mysql-test/r/type_time.result
View file @
284479c0
...
@@ -299,6 +299,34 @@ Field Type Null Key Default Extra
...
@@ -299,6 +299,34 @@ Field Type Null Key Default Extra
MAX(t1)+1 decimal(22,1) YES NULL
MAX(t1)+1 decimal(22,1) YES NULL
DROP TABLE t2,t1;
DROP TABLE t2,t1;
#
#
# MDEV-4858 Wrong results for a huge unsigned value inserted into a TIME column
#
SET sql_mode=traditional;
CREATE TABLE t1 (a TIME(6));
INSERT INTO t1 VALUES (CAST(0xFFFFFFFF00000000 AS UNSIGNED));
ERROR 22007: Incorrect time value: '18446744069414584320' for column 'a' at row 1
SET sql_mode=DEFAULT;
INSERT INTO t1 VALUES (CAST(0xFFFFFFFF00000000 AS UNSIGNED));
Warnings:
Warning 1264 Out of range value for column 'a' at row 1
SELECT * FROM t1;
a
838:59:59.999999
DROP TABLE t1;
SELECT TIME'00:00:00'> CAST(0xFFFFFFFF00000000 AS UNSIGNED);
TIME'00:00:00'> CAST(0xFFFFFFFF00000000 AS UNSIGNED)
0
Warnings:
Warning 1292 Truncated incorrect DOUBLE value: '00:00:00'
#
# MDEV-6100 No warning on CAST(9000000 AS TIME)
#
SELECT CAST(9000000 AS TIME);
CAST(9000000 AS TIME)
838:59:59
Warnings:
Warning 1292 Truncated incorrect time value: '9000000'
#
# End of 5.3 tests
# End of 5.3 tests
#
#
CREATE TABLE t1 (f1 TIME);
CREATE TABLE t1 (f1 TIME);
...
...
mysql-test/r/type_time_hires.result
View file @
284479c0
...
@@ -16,46 +16,46 @@ Warnings:
...
@@ -16,46 +16,46 @@ Warnings:
Warning 1265 Data truncated for column 'a' at row 1
Warning 1265 Data truncated for column 'a' at row 1
insert t1 values (99991231235959e1);
insert t1 values (99991231235959e1);
Warnings:
Warnings:
Warning 126
5 Data truncated
for column 'a' at row 1
Warning 126
4 Out of range value
for column 'a' at row 1
select * from t1;
select * from t1;
a
a
00:00:00.000
00:20:03.123
00:20:03.123
01:02:03.456
01:02:03.456
03:04:05.789
03:04:05.789
15:47:11.123
15:47:11.123
838:59:59.999
select truncate(a, 6) from t1;
select truncate(a, 6) from t1;
truncate(a, 6)
truncate(a, 6)
0.000000
2003.123000
2003.123000
10203.456000
10203.456000
30405.789062
30405.789062
154711.123000
154711.123000
8385959.999000
select a DIV 1 from t1;
select a DIV 1 from t1;
a DIV 1
a DIV 1
0
2003
2003
10203
10203
30405
30405
154711
154711
8385959
select group_concat(distinct a) from t1;
select group_concat(distinct a) from t1;
group_concat(distinct a)
group_concat(distinct a)
00:
00:00.000,00:20:03.123,01:02:03.456,03:04:05.789,15:47:11.123
00:
20:03.123,01:02:03.456,03:04:05.789,15:47:11.123,838:59:59.999
alter table t1 engine=innodb;
alter table t1 engine=innodb;
select * from t1 order by a;
select * from t1 order by a;
a
a
00:00:00.000
00:20:03.123
00:20:03.123
01:02:03.456
01:02:03.456
03:04:05.789
03:04:05.789
15:47:11.123
15:47:11.123
838:59:59.999
select * from t1 order by a+0;
select * from t1 order by a+0;
a
a
00:00:00.000
00:20:03.123
00:20:03.123
01:02:03.456
01:02:03.456
03:04:05.789
03:04:05.789
15:47:11.123
15:47:11.123
838:59:59.999
drop table t1;
drop table t1;
create table t1 (a time(4)) engine=innodb;
create table t1 (a time(4)) engine=innodb;
insert t1 values ('2010-12-11 01:02:03.456789');
insert t1 values ('2010-12-11 01:02:03.456789');
...
...
mysql-test/suite/funcs_1/r/innodb_func_view.result
View file @
284479c0
No preview for this file type
mysql-test/suite/funcs_1/r/memory_func_view.result
View file @
284479c0
No preview for this file type
mysql-test/suite/funcs_1/r/myisam_func_view.result
View file @
284479c0
No preview for this file type
mysql-test/t/dyncol.test
View file @
284479c0
...
@@ -626,6 +626,13 @@ INSERT INTO t1 SET dyncol = COLUMN_CREATE( 7, REPEAT('k',487), 209, REPEAT('x',4
...
@@ -626,6 +626,13 @@ INSERT INTO t1 SET dyncol = COLUMN_CREATE( 7, REPEAT('k',487), 209, REPEAT('x',4
SELECT
COLUMN_ADD
(
dyncol
,
7
,
'22:22:22'
,
8
,
REPEAT
(
'x'
,
270
)
AS
CHAR
)
FROM
t1
;
SELECT
COLUMN_ADD
(
dyncol
,
7
,
'22:22:22'
,
8
,
REPEAT
(
'x'
,
270
)
AS
CHAR
)
FROM
t1
;
DROP
table
t1
;
DROP
table
t1
;
--
echo
#
--
echo
# MDEV-4858 Wrong results for a huge unsigned value inserted into a TIME column
--
echo
#
SELECT
column_get
(
column_create
(
1
,
-
999999999999999
AS
int
),
1
AS
TIME
)
AS
t1
,
column_get
(
column_create
(
1
,
-
9223372036854775808
AS
int
),
1
AS
TIME
)
AS
t2
;
--
echo
#
--
echo
#
--
echo
# end of 5.3 tests
--
echo
# end of 5.3 tests
--
echo
#
--
echo
#
...
...
mysql-test/t/func_time.test
View file @
284479c0
...
@@ -1467,3 +1467,8 @@ CREATE TABLE t1 (i INT);
...
@@ -1467,3 +1467,8 @@ CREATE TABLE t1 (i INT);
INSERT
INTO
t1
VALUES
(
1
),(
2
);
INSERT
INTO
t1
VALUES
(
1
),(
2
);
SELECT
1
FROM
t1
GROUP
BY
MONTHNAME
(
0
)
WITH
ROLLUP
;
SELECT
1
FROM
t1
GROUP
BY
MONTHNAME
(
0
)
WITH
ROLLUP
;
DROP
TABLE
t1
;
DROP
TABLE
t1
;
--
echo
#
--
echo
# MDEV-6099 Bad results for DATE_ADD(.., INTERVAL 2000000000000000000.0 SECOND)
--
echo
#
SELECT
DATE_ADD
(
'2001-01-01 10:20:30'
,
INTERVAL
250000000000.0
SECOND
)
AS
c1
,
DATE_ADD
(
'2001-01-01 10:20:30'
,
INTERVAL
2000000000000000000.0
SECOND
)
AS
c2
;
mysql-test/t/type_datetime.test
View file @
284479c0
...
@@ -519,6 +519,14 @@ DELIMITER ;|
...
@@ -519,6 +519,14 @@ DELIMITER ;|
call
test5041
();
call
test5041
();
drop
procedure
test5041
;
drop
procedure
test5041
;
--
echo
#
--
echo
# MDEV-6097 Inconsistent results for CAST(int,decimal,double AS DATETIME)
--
echo
#
SELECT
CAST
(
010203101112
AS
DATETIME
(
1
))
AS
c1
,
CAST
(
010203101112.2
AS
DATETIME
(
1
))
AS
c2
,
CAST
(
010203101112.2
+
0
e0
AS
DATETIME
(
1
))
AS
c3
;
--
echo
End
of
5.3
tests
--
echo
End
of
5.3
tests
...
...
mysql-test/t/type_time.test
View file @
284479c0
...
@@ -201,6 +201,23 @@ SELECT * FROM t2;
...
@@ -201,6 +201,23 @@ SELECT * FROM t2;
SHOW
COLUMNS
FROM
t2
;
SHOW
COLUMNS
FROM
t2
;
DROP
TABLE
t2
,
t1
;
DROP
TABLE
t2
,
t1
;
--
echo
#
--
echo
# MDEV-4858 Wrong results for a huge unsigned value inserted into a TIME column
--
echo
#
SET
sql_mode
=
traditional
;
CREATE
TABLE
t1
(
a
TIME
(
6
));
--
error
ER_TRUNCATED_WRONG_VALUE
INSERT
INTO
t1
VALUES
(
CAST
(
0xFFFFFFFF00000000
AS
UNSIGNED
));
SET
sql_mode
=
DEFAULT
;
INSERT
INTO
t1
VALUES
(
CAST
(
0xFFFFFFFF00000000
AS
UNSIGNED
));
SELECT
*
FROM
t1
;
DROP
TABLE
t1
;
SELECT
TIME
'00:00:00'
>
CAST
(
0xFFFFFFFF00000000
AS
UNSIGNED
);
--
echo
#
--
echo
# MDEV-6100 No warning on CAST(9000000 AS TIME)
--
echo
#
SELECT
CAST
(
9000000
AS
TIME
);
--
echo
#
--
echo
#
--
echo
# End of 5.3 tests
--
echo
# End of 5.3 tests
...
...
sql-common/my_time.c
View file @
284479c0
...
@@ -1223,7 +1223,7 @@ longlong number_to_datetime(longlong nr, ulong sec_part, MYSQL_TIME *time_res,
...
@@ -1223,7 +1223,7 @@ longlong number_to_datetime(longlong nr, ulong sec_part, MYSQL_TIME *time_res,
*
was_cut
=
0
;
*
was_cut
=
0
;
time_res
->
time_type
=
MYSQL_TIMESTAMP_DATE
;
time_res
->
time_type
=
MYSQL_TIMESTAMP_DATE
;
if
(
nr
==
0
||
nr
>=
10000101000000LL
||
sec_part
)
if
(
nr
==
0
||
nr
>=
10000101000000LL
)
{
{
time_res
->
time_type
=
MYSQL_TIMESTAMP_DATETIME
;
time_res
->
time_type
=
MYSQL_TIMESTAMP_DATETIME
;
goto
ok
;
goto
ok
;
...
@@ -1281,7 +1281,11 @@ longlong number_to_datetime(longlong nr, ulong sec_part, MYSQL_TIME *time_res,
...
@@ -1281,7 +1281,11 @@ longlong number_to_datetime(longlong nr, ulong sec_part, MYSQL_TIME *time_res,
time_res
->
minute
<=
59
&&
time_res
->
second
<=
59
&&
time_res
->
minute
<=
59
&&
time_res
->
second
<=
59
&&
sec_part
<=
TIME_MAX_SECOND_PART
&&
sec_part
<=
TIME_MAX_SECOND_PART
&&
!
check_date
(
time_res
,
nr
||
sec_part
,
flags
,
was_cut
))
!
check_date
(
time_res
,
nr
||
sec_part
,
flags
,
was_cut
))
{
if
(
time_res
->
time_type
==
MYSQL_TIMESTAMP_DATE
&&
sec_part
!=
0
)
*
was_cut
=
MYSQL_TIME_NOTE_TRUNCATED
;
return
nr
;
return
nr
;
}
/* Don't want to have was_cut get set if NO_ZERO_DATE was violated. */
/* Don't want to have was_cut get set if NO_ZERO_DATE was violated. */
if
(
nr
||
!
(
flags
&
TIME_NO_ZERO_DATE
))
if
(
nr
||
!
(
flags
&
TIME_NO_ZERO_DATE
))
...
@@ -1315,10 +1319,10 @@ longlong number_to_datetime(longlong nr, ulong sec_part, MYSQL_TIME *time_res,
...
@@ -1315,10 +1319,10 @@ longlong number_to_datetime(longlong nr, ulong sec_part, MYSQL_TIME *time_res,
0 time value is valid, but was possibly truncated
0 time value is valid, but was possibly truncated
-1 time value is invalid
-1 time value is invalid
*/
*/
int
number_to_time
(
my_bool
neg
,
longlong
nr
,
ulong
sec_part
,
int
number_to_time
(
my_bool
neg
,
u
longlong
nr
,
ulong
sec_part
,
MYSQL_TIME
*
ltime
,
int
*
was_cut
)
MYSQL_TIME
*
ltime
,
int
*
was_cut
)
{
{
if
(
nr
>
9999999
&&
neg
==
0
)
if
(
nr
>
9999999
&&
n
r
<
99991231235959ULL
&&
n
eg
==
0
)
{
{
if
(
number_to_datetime
(
nr
,
sec_part
,
ltime
,
if
(
number_to_datetime
(
nr
,
sec_part
,
ltime
,
TIME_INVALID_DATES
,
was_cut
)
<
0
)
TIME_INVALID_DATES
,
was_cut
)
<
0
)
...
@@ -1326,7 +1330,7 @@ int number_to_time(my_bool neg, longlong nr, ulong sec_part,
...
@@ -1326,7 +1330,7 @@ int number_to_time(my_bool neg, longlong nr, ulong sec_part,
ltime
->
year
=
ltime
->
month
=
ltime
->
day
=
0
;
ltime
->
year
=
ltime
->
month
=
ltime
->
day
=
0
;
ltime
->
time_type
=
MYSQL_TIMESTAMP_TIME
;
ltime
->
time_type
=
MYSQL_TIMESTAMP_TIME
;
*
was_cut
=
MYSQL_TIME_
WARN
_TRUNCATED
;
*
was_cut
=
MYSQL_TIME_
NOTE
_TRUNCATED
;
return
0
;
return
0
;
}
}
...
...
sql/field.cc
View file @
284479c0
...
@@ -4576,7 +4576,7 @@ int Field_timestamp::store(longlong nr, bool unsigned_val)
...
@@ -4576,7 +4576,7 @@ int Field_timestamp::store(longlong nr, bool unsigned_val)
{
{
MYSQL_TIME
l_time
;
MYSQL_TIME
l_time
;
int
error
;
int
error
;
ErrConvInteger
str
(
nr
);
ErrConvInteger
str
(
nr
,
unsigned_val
);
THD
*
thd
=
table
->
in_use
;
THD
*
thd
=
table
->
in_use
;
/* We don't want to store invalid or fuzzy datetime values in TIMESTAMP */
/* We don't want to store invalid or fuzzy datetime values in TIMESTAMP */
...
@@ -4952,6 +4952,17 @@ int Field_temporal::store_TIME_with_warning(MYSQL_TIME *ltime,
...
@@ -4952,6 +4952,17 @@ int Field_temporal::store_TIME_with_warning(MYSQL_TIME *ltime,
ASSERT_COLUMN_MARKED_FOR_WRITE_OR_COMPUTED
;
ASSERT_COLUMN_MARKED_FOR_WRITE_OR_COMPUTED
;
#if MARIADB_VERSION_ID < 1000000
/*
Check if the YYYYMMDD part was truncated.
Translate a note into a warning.
In MariaDB-10.0 we have a better warnings/notes handling,
so this code is not needed.
*/
if
(
was_cut
&
MYSQL_TIME_NOTE_TRUNCATED
)
was_cut
|=
MYSQL_TIME_WARN_TRUNCATED
;
#endif
if
(
was_cut
==
0
&&
if
(
was_cut
==
0
&&
have_smth_to_conv
==
0
&&
have_smth_to_conv
==
0
&&
mysql_type_to_time_type
(
type
())
!=
MYSQL_TIMESTAMP_TIME
)
// special case: zero date
mysql_type_to_time_type
(
type
())
!=
MYSQL_TIMESTAMP_TIME
)
// special case: zero date
...
@@ -5042,7 +5053,7 @@ int Field_temporal::store(longlong nr, bool unsigned_val)
...
@@ -5042,7 +5053,7 @@ int Field_temporal::store(longlong nr, bool unsigned_val)
MYSQL_TIME
ltime
;
MYSQL_TIME
ltime
;
longlong
tmp
;
longlong
tmp
;
THD
*
thd
=
table
->
in_use
;
THD
*
thd
=
table
->
in_use
;
ErrConvInteger
str
(
nr
);
ErrConvInteger
str
(
nr
,
unsigned_val
);
tmp
=
number_to_datetime
(
nr
,
0
,
&
ltime
,
(
thd
->
variables
.
sql_mode
&
tmp
=
number_to_datetime
(
nr
,
0
,
&
ltime
,
(
thd
->
variables
.
sql_mode
&
(
MODE_NO_ZERO_IN_DATE
|
(
MODE_NO_ZERO_IN_DATE
|
...
@@ -5140,7 +5151,7 @@ int Field_time::store(double nr)
...
@@ -5140,7 +5151,7 @@ int Field_time::store(double nr)
bool
neg
=
nr
<
0
;
bool
neg
=
nr
<
0
;
if
(
neg
)
if
(
neg
)
nr
=
-
nr
;
nr
=
-
nr
;
int
have_smth_to_conv
=
!
number_to_time
(
neg
,
(
longlong
)
nr
,
int
have_smth_to_conv
=
!
number_to_time
(
neg
,
(
ulonglong
)
nr
,
(
ulong
)((
nr
-
floor
(
nr
))
*
TIME_SECOND_PART_FACTOR
),
(
ulong
)((
nr
-
floor
(
nr
))
*
TIME_SECOND_PART_FACTOR
),
&
ltime
,
&
was_cut
);
&
ltime
,
&
was_cut
);
...
@@ -5151,9 +5162,12 @@ int Field_time::store(double nr)
...
@@ -5151,9 +5162,12 @@ int Field_time::store(double nr)
int
Field_time
::
store
(
longlong
nr
,
bool
unsigned_val
)
int
Field_time
::
store
(
longlong
nr
,
bool
unsigned_val
)
{
{
MYSQL_TIME
ltime
;
MYSQL_TIME
ltime
;
ErrConvInteger
str
(
nr
);
ErrConvInteger
str
(
nr
,
unsigned_val
);
int
was_cut
;
int
was_cut
;
int
have_smth_to_conv
=
!
number_to_time
(
nr
<
0
,
nr
<
0
?
-
nr
:
nr
,
if
(
nr
<
0
&&
unsigned_val
)
nr
=
99991231235959LL
+
1
;
int
have_smth_to_conv
=
!
number_to_time
(
nr
<
0
,
(
ulonglong
)
(
nr
<
0
?
-
nr
:
nr
),
0
,
&
ltime
,
&
was_cut
);
0
,
&
ltime
,
&
was_cut
);
return
store_TIME_with_warning
(
&
ltime
,
&
str
,
was_cut
,
have_smth_to_conv
);
return
store_TIME_with_warning
(
&
ltime
,
&
str
,
was_cut
,
have_smth_to_conv
);
...
@@ -5520,7 +5534,8 @@ bool Field_year::get_date(MYSQL_TIME *ltime,ulonglong fuzzydate)
...
@@ -5520,7 +5534,8 @@ bool Field_year::get_date(MYSQL_TIME *ltime,ulonglong fuzzydate)
int
tmp
=
(
int
)
ptr
[
0
];
int
tmp
=
(
int
)
ptr
[
0
];
if
(
tmp
||
field_length
!=
4
)
if
(
tmp
||
field_length
!=
4
)
tmp
+=
1900
;
tmp
+=
1900
;
return
int_to_datetime_with_warn
(
tmp
*
10000
,
ltime
,
fuzzydate
,
field_name
);
return
int_to_datetime_with_warn
(
false
,
tmp
*
10000
,
ltime
,
fuzzydate
,
field_name
);
}
}
...
...
sql/item.cc
View file @
284479c0
...
@@ -1302,6 +1302,7 @@ bool Item::get_date(MYSQL_TIME *ltime,ulonglong fuzzydate)
...
@@ -1302,6 +1302,7 @@ bool Item::get_date(MYSQL_TIME *ltime,ulonglong fuzzydate)
case
INT_RESULT
:
case
INT_RESULT
:
{
{
longlong
value
=
val_int
();
longlong
value
=
val_int
();
bool
neg
=
!
unsigned_flag
&&
value
<
0
;
if
(
field_type
()
==
MYSQL_TYPE_YEAR
)
if
(
field_type
()
==
MYSQL_TYPE_YEAR
)
{
{
if
(
max_length
==
2
)
if
(
max_length
==
2
)
...
@@ -1313,7 +1314,8 @@ bool Item::get_date(MYSQL_TIME *ltime,ulonglong fuzzydate)
...
@@ -1313,7 +1314,8 @@ bool Item::get_date(MYSQL_TIME *ltime,ulonglong fuzzydate)
}
}
value
*=
10000
;
/* make it YYYYMMHH */
value
*=
10000
;
/* make it YYYYMMHH */
}
}
if
(
null_value
||
int_to_datetime_with_warn
(
value
,
ltime
,
fuzzydate
,
if
(
null_value
||
int_to_datetime_with_warn
(
neg
,
neg
?
-
value
:
value
,
ltime
,
fuzzydate
,
field_name_or_null
()))
field_name_or_null
()))
goto
err
;
goto
err
;
break
;
break
;
...
...
sql/item_func.cc
View file @
284479c0
...
@@ -1118,7 +1118,9 @@ bool Item_func_hybrid_result_type::get_date(MYSQL_TIME *ltime,
...
@@ -1118,7 +1118,9 @@ bool Item_func_hybrid_result_type::get_date(MYSQL_TIME *ltime,
case
INT_RESULT
:
case
INT_RESULT
:
{
{
longlong
value
=
int_op
();
longlong
value
=
int_op
();
if
(
null_value
||
int_to_datetime_with_warn
(
value
,
ltime
,
fuzzydate
,
bool
neg
=
!
unsigned_flag
&&
value
<
0
;
if
(
null_value
||
int_to_datetime_with_warn
(
neg
,
neg
?
-
value
:
value
,
ltime
,
fuzzydate
,
field_name_or_null
()))
field_name_or_null
()))
goto
err
;
goto
err
;
break
;
break
;
...
...
sql/item_strfunc.cc
View file @
284479c0
...
@@ -4424,8 +4424,10 @@ bool Item_dyncol_get::get_date(MYSQL_TIME *ltime, ulonglong fuzzy_date)
...
@@ -4424,8 +4424,10 @@ bool Item_dyncol_get::get_date(MYSQL_TIME *ltime, ulonglong fuzzy_date)
case
DYN_COL_UINT
:
case
DYN_COL_UINT
:
if
(
signed_value
||
val
.
x
.
ulong_value
<=
LONGLONG_MAX
)
if
(
signed_value
||
val
.
x
.
ulong_value
<=
LONGLONG_MAX
)
{
{
if
(
int_to_datetime_with_warn
(
val
.
x
.
ulong_value
,
ltime
,
fuzzy_date
,
bool
neg
=
val
.
x
.
ulong_value
>
LONGLONG_MAX
;
0
/* TODO */
))
if
(
int_to_datetime_with_warn
(
neg
,
neg
?
-
val
.
x
.
ulong_value
:
val
.
x
.
ulong_value
,
ltime
,
fuzzy_date
,
0
/* TODO */
))
goto
null
;
goto
null
;
return
0
;
return
0
;
}
}
...
...
sql/item_timefunc.cc
View file @
284479c0
...
@@ -1298,6 +1298,18 @@ bool get_interval_value(Item *args,interval_type int_type, INTERVAL *interval)
...
@@ -1298,6 +1298,18 @@ bool get_interval_value(Item *args,interval_type int_type, INTERVAL *interval)
if
(
!
(
val
=
args
->
val_decimal
(
&
decimal_value
)))
if
(
!
(
val
=
args
->
val_decimal
(
&
decimal_value
)))
return
true
;
return
true
;
interval
->
neg
=
my_decimal2seconds
(
val
,
&
second
,
&
second_part
);
interval
->
neg
=
my_decimal2seconds
(
val
,
&
second
,
&
second_part
);
if
(
second
==
LONGLONG_MAX
)
{
char
buff
[
DECIMAL_MAX_STR_LENGTH
];
int
length
=
sizeof
(
buff
);
decimal2string
(
val
,
buff
,
&
length
,
0
,
0
,
0
);
push_warning_printf
(
current_thd
,
MYSQL_ERROR
::
WARN_LEVEL_WARN
,
ER_TRUNCATED_WRONG_VALUE
,
ER
(
ER_TRUNCATED_WRONG_VALUE
),
"DECIMAL"
,
buff
);
return
true
;
}
interval
->
second
=
second
;
interval
->
second
=
second
;
interval
->
second_part
=
second_part
;
interval
->
second_part
=
second_part
;
return
false
;
return
false
;
...
...
sql/sql_error.h
View file @
284479c0
...
@@ -544,11 +544,16 @@ class ErrConvString : public ErrConv
...
@@ -544,11 +544,16 @@ class ErrConvString : public ErrConv
class
ErrConvInteger
:
public
ErrConv
class
ErrConvInteger
:
public
ErrConv
{
{
longlong
num
;
longlong
m_value
;
bool
m_unsigned
;
public:
public:
ErrConvInteger
(
longlong
num_arg
)
:
ErrConv
(),
num
(
num_arg
)
{}
ErrConvInteger
(
longlong
num_arg
,
bool
unsigned_flag
=
false
)
:
ErrConv
(),
m_value
(
num_arg
),
m_unsigned
(
unsigned_flag
)
{}
const
char
*
ptr
()
const
const
char
*
ptr
()
const
{
return
llstr
(
num
,
err_buffer
);
}
{
return
m_unsigned
?
ullstr
(
m_value
,
err_buffer
)
:
llstr
(
m_value
,
err_buffer
);
}
};
};
class
ErrConvDouble
:
public
ErrConv
class
ErrConvDouble
:
public
ErrConv
...
...
sql/sql_time.cc
View file @
284479c0
...
@@ -360,20 +360,23 @@ static bool number_to_time_with_warn(bool neg, ulonglong nr, ulong sec_part,
...
@@ -360,20 +360,23 @@ static bool number_to_time_with_warn(bool neg, ulonglong nr, ulong sec_part,
int
was_cut
;
int
was_cut
;
longlong
res
;
longlong
res
;
enum_field_types
f_type
;
enum_field_types
f_type
;
bool
have_warnings
;
if
(
fuzzydate
&
TIME_TIME_ONLY
)
if
(
fuzzydate
&
TIME_TIME_ONLY
)
{
{
fuzzydate
=
TIME_TIME_ONLY
;
// clear other flags
fuzzydate
=
TIME_TIME_ONLY
;
// clear other flags
f_type
=
MYSQL_TYPE_TIME
;
f_type
=
MYSQL_TYPE_TIME
;
res
=
number_to_time
(
neg
,
nr
,
sec_part
,
ltime
,
&
was_cut
);
res
=
number_to_time
(
neg
,
nr
,
sec_part
,
ltime
,
&
was_cut
);
have_warnings
=
MYSQL_TIME_WARN_HAVE_WARNINGS
(
was_cut
);
}
}
else
else
{
{
f_type
=
MYSQL_TYPE_DATETIME
;
f_type
=
MYSQL_TYPE_DATETIME
;
res
=
neg
?
-
1
:
number_to_datetime
(
nr
,
sec_part
,
ltime
,
fuzzydate
,
&
was_cut
);
res
=
neg
?
-
1
:
number_to_datetime
(
nr
,
sec_part
,
ltime
,
fuzzydate
,
&
was_cut
);
have_warnings
=
was_cut
&&
(
fuzzydate
&
TIME_NO_ZERO_IN_DATE
);
}
}
if
(
res
<
0
||
(
was_cut
&&
(
fuzzydate
&
TIME_NO_ZERO_IN_DATE
))
)
if
(
res
<
0
||
have_warnings
)
{
{
make_truncated_value_warning
(
current_thd
,
make_truncated_value_warning
(
current_thd
,
MYSQL_ERROR
::
WARN_LEVEL_WARN
,
str
,
MYSQL_ERROR
::
WARN_LEVEL_WARN
,
str
,
...
@@ -416,12 +419,11 @@ bool decimal_to_datetime_with_warn(const my_decimal *value, MYSQL_TIME *ltime,
...
@@ -416,12 +419,11 @@ bool decimal_to_datetime_with_warn(const my_decimal *value, MYSQL_TIME *ltime,
}
}
bool
int_to_datetime_with_warn
(
longlong
value
,
MYSQL_TIME
*
ltime
,
bool
int_to_datetime_with_warn
(
bool
neg
,
u
longlong
value
,
MYSQL_TIME
*
ltime
,
ulonglong
fuzzydate
,
const
char
*
field_name
)
ulonglong
fuzzydate
,
const
char
*
field_name
)
{
{
const
ErrConvInteger
str
(
value
);
const
ErrConvInteger
str
(
neg
?
-
value
:
value
,
!
neg
);
bool
neg
=
value
<
0
;
return
number_to_time_with_warn
(
neg
,
value
,
0
,
ltime
,
return
number_to_time_with_warn
(
neg
,
neg
?
-
value
:
value
,
0
,
ltime
,
fuzzydate
,
&
str
,
field_name
);
fuzzydate
,
&
str
,
field_name
);
}
}
...
...
sql/sql_time.h
View file @
284479c0
...
@@ -48,7 +48,7 @@ bool double_to_datetime_with_warn(double value, MYSQL_TIME *ltime,
...
@@ -48,7 +48,7 @@ bool double_to_datetime_with_warn(double value, MYSQL_TIME *ltime,
bool
decimal_to_datetime_with_warn
(
const
my_decimal
*
value
,
MYSQL_TIME
*
ltime
,
bool
decimal_to_datetime_with_warn
(
const
my_decimal
*
value
,
MYSQL_TIME
*
ltime
,
ulonglong
fuzzydate
,
ulonglong
fuzzydate
,
const
char
*
name
);
const
char
*
name
);
bool
int_to_datetime_with_warn
(
longlong
value
,
MYSQL_TIME
*
ltime
,
bool
int_to_datetime_with_warn
(
bool
neg
,
u
longlong
value
,
MYSQL_TIME
*
ltime
,
ulonglong
fuzzydate
,
ulonglong
fuzzydate
,
const
char
*
name
);
const
char
*
name
);
...
...
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