Skip to content
Snippets Groups Projects
Unverified Commit 8a4e55e4 authored by Yahor Yuzefovich's avatar Yahor Yuzefovich Committed by GitHub
Browse files

Merge pull request #126208 from cockroachdb/blathers/backport-release-23.2.7-rc-125504

release-23.2.7-rc: execbuilder: fix nil pointer in tryBuildFastPathInsert
parents 9545977a a5c119cd
Loading
......@@ -1048,3 +1048,23 @@ statement error pgcode 23505 duplicate key value violates unique constraint \"un
INSERT INTO t115377 VALUES (2, 1, 1, 'east')
subtest end
# Regression test for hitting a nil pointer in the insert fast path when seeing
# a bool expression in the VALUES clause (#123103).
statement ok
CREATE TABLE t123103 (
id STRING DEFAULT gen_random_uuid()::STRING NOT NULL,
r region NOT NULL DEFAULT 'us-east'::region,
a STRING NOT NULL,
b BOOL NOT NULL,
CONSTRAINT tab_pkey PRIMARY KEY (r ASC, id ASC),
CONSTRAINT tab_id_key UNIQUE WITHOUT INDEX (id ASC),
CONSTRAINT tab_r_a_b_key UNIQUE (r ASC, a ASC, b ASC),
CONSTRAINT tab_a_b_key UNIQUE WITHOUT INDEX (a ASC, b ASC)
);
INSERT INTO t123103 (id, a, b) VALUES ('1234567890', 'foo', true);
query TTB
SELECT id, a, b FROM t123103;
----
1234567890 foo true
......@@ -193,8 +193,18 @@ func (b *Builder) tryBuildFastPathInsert(ins *memo.InsertExpr) (_ execPlan, ok b
panic(errors.AssertionFailedf("expected %d tuple elements in insert fast path uniqueness check, found %d", len(c.InsertCols), len(tuple.Elems)))
}
for k := 0; k < len(tuple.Elems); k++ {
constExpr, _ := tuple.Elems[k].(*memo.ConstExpr)
execFastPathCheck.DatumsFromConstraint[j][execFastPathCheck.InsertCols[k]] = constExpr.Value
var constDatum tree.Datum
switch e := tuple.Elems[k].(type) {
case *memo.ConstExpr:
constDatum = e.Value
case *memo.TrueExpr:
constDatum = tree.DBoolTrue
case *memo.FalseExpr:
constDatum = tree.DBoolFalse
default:
return execPlan{}, false, nil
}
execFastPathCheck.DatumsFromConstraint[j][execFastPathCheck.InsertCols[k]] = constDatum
}
}
uniqCheck := &ins.UniqueChecks[i]
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment