Skip to content

Commit

Permalink
cherry pick pingcap#27244 to release-5.0
Browse files Browse the repository at this point in the history
Signed-off-by: ti-srebot <ti-srebot@pingcap.com>
  • Loading branch information
lzmhhh123 authored and ti-srebot committed Aug 20, 2021
1 parent dbc8017 commit b58c62c
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 0 deletions.
10 changes: 10 additions & 0 deletions executor/executor_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -4951,6 +4951,16 @@ func (s *testSuiteP2) TestAddDateBuiltinWithWarnings(c *C) {
tk.MustQuery("show warnings").Check(testutil.RowsWithSep("|", "Warning|1292|Incorrect datetime value: '2001-01-00'"))
}

func (s *testSuiteP2) TestIssue27232(c *C) {
tk := testkit.NewTestKit(c, s.store)
tk.MustExec("use test")
tk.MustExec("drop table if exists t")
tk.MustExec("create table t (a timestamp)")
tk.MustExec("insert into t values (\"1970-07-23 10:04:59\"), (\"2038-01-19 03:14:07\")")
tk.MustQuery("select * from t where date_sub(a, interval 10 month) = date_sub(\"1970-07-23 10:04:59\", interval 10 month)").Check(testkit.Rows("1970-07-23 10:04:59"))
tk.MustQuery("select * from t where timestampadd(hour, 1, a ) = timestampadd(hour, 1, \"2038-01-19 03:14:07\")").Check(testkit.Rows("2038-01-19 03:14:07"))
}

func (s *testSuiteP2) TestStrToDateBuiltinWithWarnings(c *C) {
tk := testkit.NewTestKit(c, s.store)
tk.MustExec("set @@sql_mode='NO_ZERO_DATE'")
Expand Down
20 changes: 20 additions & 0 deletions expression/builtin_time.go
Original file line number Diff line number Diff line change
Expand Up @@ -3348,6 +3348,16 @@ func (c *addDateFunctionClass) getFunction(ctx sessionctx.Context, args []Expres
if err != nil {
return nil, err
}
if dateEvalTp == types.ETDatetime && args[0].GetType().Tp == mysql.TypeTimestamp {
tp := types.NewFieldType(mysql.TypeDatetime)
tp.Decimal = args[0].GetType().Decimal
tp.Flen = mysql.MaxDatetimeWidthNoFsp
if tp.Decimal > 0 {
tp.Flen = tp.Flen + 1 + tp.Decimal
}
types.SetBinChsClnFlag(tp)
args[0] = BuildCastFunction(ctx, args[0], tp)
}
bf.tp.Flen, bf.tp.Decimal = mysql.MaxDatetimeFullWidth, types.UnspecifiedLength
}

Expand Down Expand Up @@ -4022,6 +4032,16 @@ func (c *subDateFunctionClass) getFunction(ctx sessionctx.Context, args []Expres
if err != nil {
return nil, err
}
if dateEvalTp == types.ETDatetime && args[0].GetType().Tp == mysql.TypeTimestamp {
tp := types.NewFieldType(mysql.TypeDatetime)
tp.Decimal = args[0].GetType().Decimal
tp.Flen = mysql.MaxDatetimeWidthNoFsp
if tp.Decimal > 0 {
tp.Flen = tp.Flen + 1 + tp.Decimal
}
types.SetBinChsClnFlag(tp)
args[0] = BuildCastFunction(ctx, args[0], tp)
}
bf.tp.Flen, bf.tp.Decimal = mysql.MaxDatetimeFullWidth, types.UnspecifiedLength
}

Expand Down

0 comments on commit b58c62c

Please sign in to comment.