Skip to content

Commit

Permalink
optimize: only inserted fields (apache#719)
Browse files Browse the repository at this point in the history
* only inserted fields

* It is suspected that it is not used, so restore the previous code

---------

Co-authored-by: JayLiu <[email protected]>
  • Loading branch information
lxfeng1997 and luky116 authored Dec 15, 2024
1 parent 6bf7b94 commit d7b6a4c
Show file tree
Hide file tree
Showing 3 changed files with 56 additions and 5 deletions.
43 changes: 43 additions & 0 deletions pkg/datasource/sql/exec/at/base_executor.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ import (
"database/sql"
"database/sql/driver"
"fmt"
"seata.apache.org/seata-go/pkg/datasource/sql/undo"
"strings"

"github.com/arana-db/parser/ast"
Expand Down Expand Up @@ -187,6 +188,48 @@ func (b *baseExecutor) buildRecordImages(rowsi driver.Rows, tableMetaData *types
return &types.RecordImage{TableName: tableMetaData.TableName, Rows: rowImages, SQLType: sqlType}, nil
}

func (b *baseExecutor) getNeedColumns(meta *types.TableMeta, columns []string, dbType types.DBType) []string {
var needUpdateColumns []string
if undo.UndoConfig.OnlyCareUpdateColumns && columns != nil && len(columns) > 0 {
needUpdateColumns = columns
if !b.containsPKByName(meta, columns) {
pkNames := meta.GetPrimaryKeyOnlyName()
if pkNames != nil && len(pkNames) > 0 {
for _, name := range pkNames {
needUpdateColumns = append(needUpdateColumns, name)
}
}
}
// todo If it contains onUpdate columns, add onUpdate columns
} else {
needUpdateColumns = meta.ColumnNames
}

for i := range needUpdateColumns {
needUpdateColumns[i] = AddEscape(needUpdateColumns[i], dbType)
}
return needUpdateColumns
}

func (b *baseExecutor) containsPKByName(meta *types.TableMeta, columns []string) bool {
pkColumnNameList := meta.GetPrimaryKeyOnlyName()
if len(pkColumnNameList) == 0 {
return false
}

matchCounter := 0
for _, column := range columns {
for _, pkName := range pkColumnNameList {
if strings.EqualFold(pkName, column) ||
strings.EqualFold(pkName, strings.ToLower(column)) {
matchCounter++
}
}
}

return matchCounter == len(pkColumnNameList)
}

func getSqlNullValue(value interface{}) interface{} {
if value == nil {
return nil
Expand Down
14 changes: 11 additions & 3 deletions pkg/datasource/sql/exec/at/insert_executor.go
Original file line number Diff line number Diff line change
Expand Up @@ -184,9 +184,17 @@ func (i *insertExecutor) buildAfterImageSQL(ctx context.Context) (string, []driv
}
// build check sql
sb := strings.Builder{}
sb.WriteString("SELECT * FROM " + tableName)
whereSQL := i.buildWhereConditionByPKs(pkColumnNameList, len(pkValuesMap[pkColumnNameList[0]]), "mysql", maxInSize)
sb.WriteString(" WHERE " + whereSQL + " ")
suffix := strings.Builder{}
var insertColumns []string

for _, column := range i.parserCtx.InsertStmt.Columns {
insertColumns = append(insertColumns, column.Name.O)
}
sb.WriteString("SELECT " + strings.Join(i.getNeedColumns(meta, insertColumns, types.DBTypeMySQL), ", "))
suffix.WriteString(" FROM " + tableName)
whereSQL := i.buildWhereConditionByPKs(pkColumnNameList, rowSize, "mysql", maxInSize)
suffix.WriteString(" WHERE " + whereSQL + " ")
sb.WriteString(suffix.String())
return sb.String(), i.buildPKParams(pkRowImages, pkColumnNameList), nil
}

Expand Down
4 changes: 2 additions & 2 deletions pkg/datasource/sql/exec/at/insert_executor_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ func TestBuildSelectSQLByInsert(t *testing.T) {
},
},

expectQuery: "SELECT * FROM user WHERE (`id`) IN ((?),(?)) ",
expectQuery: "SELECT id, name FROM user WHERE (`id`) IN ((?),(?)) ",
expectQueryArgs: []driver.Value{int64(19), int64(21)},
},
{
Expand Down Expand Up @@ -107,7 +107,7 @@ func TestBuildSelectSQLByInsert(t *testing.T) {
},
},
},
expectQuery: "SELECT * FROM user WHERE (`user_id`) IN ((?)) ",
expectQuery: "SELECT user_id, name FROM user WHERE (`user_id`) IN ((?)) ",
expectQueryArgs: []driver.Value{int64(20)},
},
}
Expand Down

0 comments on commit d7b6a4c

Please sign in to comment.