Skip to content

Commit

Permalink
executor: fix data race in the buildMemTableReader (#43431) (#55674)
Browse files Browse the repository at this point in the history
close #43118
  • Loading branch information
ti-chi-bot committed Aug 28, 2024
1 parent d5c96a0 commit 6ea9184
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 12 deletions.
6 changes: 1 addition & 5 deletions executor/mem_reader.go
Original file line number Diff line number Diff line change
Expand Up @@ -216,11 +216,7 @@ func buildMemTableReader(ctx context.Context, us *UnionScanExec, tblReader *Tabl
}

defVal := func(i int) ([]byte, error) {
sessVars := us.ctx.GetSessionVars()
originStrict := sessVars.StrictSQLMode
sessVars.StrictSQLMode = false
d, err := table.GetColOriginDefaultValue(us.ctx, us.columns[i])
sessVars.StrictSQLMode = originStrict
d, err := table.GetColOriginDefaultValueWithoutStrictSQLMode(us.ctx, us.columns[i])
if err != nil {
return nil, err
}
Expand Down
31 changes: 24 additions & 7 deletions table/column.go
Original file line number Diff line number Diff line change
Expand Up @@ -489,9 +489,20 @@ func CheckNotNull(cols []*Column, row []types.Datum) error {
return nil
}

type getColOriginDefaultValue struct {
StrictSQLMode bool
}

// GetColOriginDefaultValue gets default value of the column from original default value.
func GetColOriginDefaultValue(ctx sessionctx.Context, col *model.ColumnInfo) (types.Datum, error) {
return getColDefaultValue(ctx, col, col.GetOriginDefaultValue())
return getColDefaultValue(ctx, col, col.GetOriginDefaultValue(), nil)
}

// GetColOriginDefaultValueWithoutStrictSQLMode gets default value of the column from original default value with Strict SQL mode.
func GetColOriginDefaultValueWithoutStrictSQLMode(ctx sessionctx.Context, col *model.ColumnInfo) (types.Datum, error) {
return getColDefaultValue(ctx, col, col.GetOriginDefaultValue(), &getColOriginDefaultValue{
StrictSQLMode: false,
})
}

// CheckNoDefaultValueForInsert checks if the column has no default value before insert data.
Expand All @@ -514,7 +525,7 @@ func CheckNoDefaultValueForInsert(sc *stmtctx.StatementContext, col *model.Colum
func GetColDefaultValue(ctx sessionctx.Context, col *model.ColumnInfo) (types.Datum, error) {
defaultValue := col.GetDefaultValue()
if !col.DefaultIsExpr {
return getColDefaultValue(ctx, col, defaultValue)
return getColDefaultValue(ctx, col, defaultValue, nil)
}
return getColDefaultExprValue(ctx, col, defaultValue.(string))
}
Expand Down Expand Up @@ -552,9 +563,9 @@ func getColDefaultExprValue(ctx sessionctx.Context, col *model.ColumnInfo, defau
return value, nil
}

func getColDefaultValue(ctx sessionctx.Context, col *model.ColumnInfo, defaultVal interface{}) (types.Datum, error) {
func getColDefaultValue(ctx sessionctx.Context, col *model.ColumnInfo, defaultVal interface{}, args *getColOriginDefaultValue) (types.Datum, error) {
if defaultVal == nil {
return getColDefaultValueFromNil(ctx, col)
return getColDefaultValueFromNil(ctx, col, args)
}

if col.GetType() != mysql.TypeTimestamp && col.GetType() != mysql.TypeDatetime {
Expand Down Expand Up @@ -595,7 +606,7 @@ func getColDefaultValue(ctx sessionctx.Context, col *model.ColumnInfo, defaultVa
return value, nil
}

func getColDefaultValueFromNil(ctx sessionctx.Context, col *model.ColumnInfo) (types.Datum, error) {
func getColDefaultValueFromNil(ctx sessionctx.Context, col *model.ColumnInfo, args *getColOriginDefaultValue) (types.Datum, error) {
if !mysql.HasNotNullFlag(col.GetFlag()) {
return types.Datum{}, nil
}
Expand All @@ -614,7 +625,13 @@ func getColDefaultValueFromNil(ctx sessionctx.Context, col *model.ColumnInfo) (t
}
vars := ctx.GetSessionVars()
sc := vars.StmtCtx
if !vars.StrictSQLMode {
var strictSQLMode bool
if args != nil {
strictSQLMode = args.StrictSQLMode
} else {
strictSQLMode = vars.StrictSQLMode
}
if !strictSQLMode {
sc.AppendWarning(ErrNoDefaultValue.FastGenByArgs(col.Name))
return GetZeroValue(col), nil
}
Expand All @@ -628,7 +645,7 @@ func getColDefaultValueFromNil(ctx sessionctx.Context, col *model.ColumnInfo) (t
sc.AppendWarning(err)
return GetZeroValue(col), nil
}
return types.Datum{}, ErrNoDefaultValue.FastGenByArgs(col.Name)
return types.Datum{}, ErrNoDefaultValue.GenWithStackByArgs(col.Name)
}

// GetZeroValue gets zero value for given column type.
Expand Down

0 comments on commit 6ea9184

Please sign in to comment.