Skip to content

Commit

Permalink
determine tuple type for hash in comparator
Browse files Browse the repository at this point in the history
  • Loading branch information
James Cor committed Sep 4, 2024
1 parent a3835e6 commit 86819fd
Showing 1 changed file with 27 additions and 0 deletions.
27 changes: 27 additions & 0 deletions sql/expression/in.go
Original file line number Diff line number Diff line change
Expand Up @@ -246,6 +246,29 @@ func newInMap(ctx *sql.Context, right Tuple, lType sql.Type) (map[uint64]sql.Exp
return elements, hasNull, nil
}

// getTupleCollation returns the collation to use for a tuple.
// If the tuple consists entirely of string types with the same collation, that collation is returned.
// Otherwise, Default collation is returned.
func getTupleCollation(tup types.TupleType) sql.CollationID {
coll := sql.Collation_Unspecified
for _, typ := range tup {
// if any element is not text, return default
if !types.IsTextOnly(typ) {
return sql.Collation_Default
}
// all text elements must have the same collation
c := typ.(sql.StringType).Collation()
if coll == sql.Collation_Unspecified {
coll = c
continue
}
if coll != c {
return sql.Collation_Default
}
}
return coll
}

func hashOfSimple(ctx *sql.Context, i interface{}, t sql.Type) (uint64, error) {
if i == nil {
return 0, nil
Expand All @@ -265,6 +288,10 @@ func hashOfSimple(ctx *sql.Context, i interface{}, t sql.Type) (uint64, error) {
str = converted.(string)
}
} else {
if types.IsTuple(t) {
coll = getTupleCollation(t.(types.TupleType))
}

x, err := convertOrTruncate(ctx, i, t.Promote())
if err != nil {
return 0, err
Expand Down

0 comments on commit 86819fd

Please sign in to comment.