From 7f3ae002a0d4a0554e7351a84a44d57ec45d5ca1 Mon Sep 17 00:00:00 2001 From: DQYuan <932087612@qq.com> Date: Wed, 19 Jun 2019 14:33:07 +0800 Subject: [PATCH] fix delete empty string bug (#10861) --- executor/executor_test.go | 1 + types/convert.go | 4 ++++ types/convert_test.go | 23 +++++++++++++++++++++++ 3 files changed, 28 insertions(+) diff --git a/executor/executor_test.go b/executor/executor_test.go index 0f8a251c5d5e0..6c1ede5cdb31e 100644 --- a/executor/executor_test.go +++ b/executor/executor_test.go @@ -336,6 +336,7 @@ func checkCases(tests []testCase, ld *executor.LoadDataInfo, ctx.GetSessionVars().StmtCtx.DupKeyAsWarning = true ctx.GetSessionVars().StmtCtx.BadNullAsWarning = true ctx.GetSessionVars().StmtCtx.InLoadDataStmt = true + ctx.GetSessionVars().StmtCtx.InDeleteStmt = false data, reachLimit, err1 := ld.InsertData(tt.data1, tt.data2) c.Assert(err1, IsNil) c.Assert(reachLimit, IsFalse) diff --git a/types/convert.go b/types/convert.go index 4764e62dd1c7e..fe0f1aaac93ff 100644 --- a/types/convert.go +++ b/types/convert.go @@ -550,6 +550,10 @@ func ConvertJSONToDecimal(sc *stmtctx.StatementContext, j json.BinaryJSON) (*MyD // getValidFloatPrefix gets prefix of string which can be successfully parsed as float. func getValidFloatPrefix(sc *stmtctx.StatementContext, s string) (valid string, err error) { + if sc.InDeleteStmt && s == "" { + return "0", nil + } + var ( sawDot bool sawDigit bool diff --git a/types/convert_test.go b/types/convert_test.go index dd50805cb6122..84836ac322238 100644 --- a/types/convert_test.go +++ b/types/convert_test.go @@ -459,6 +459,29 @@ func (s *testTypeConvertSuite) TestStrToNum(c *C) { testStrToFloat(c, "1e649", math.MaxFloat64, false, nil) testStrToFloat(c, "-1e649", -math.MaxFloat64, true, ErrTruncatedWrongVal) testStrToFloat(c, "-1e649", -math.MaxFloat64, false, nil) + + // for issue #10806 + testDeleteEmptyStringError(c) +} + +func testDeleteEmptyStringError(c *C) { + sc := new(stmtctx.StatementContext) + sc.InDeleteStmt = true + + str := "" + expect := 0 + + val, err := StrToInt(sc, str) + c.Assert(err, IsNil) + c.Assert(val, Equals, int64(expect)) + + val1, err := StrToUint(sc, str) + c.Assert(err, IsNil) + c.Assert(val1, Equals, uint64(expect)) + + val2, err := StrToFloat(sc, str) + c.Assert(err, IsNil) + c.Assert(val2, Equals, float64(expect)) } func (s *testTypeConvertSuite) TestFieldTypeToStr(c *C) {