diff --git a/pkg/cmd/roachtest/tests/logical_data_replication.go b/pkg/cmd/roachtest/tests/logical_data_replication.go index 3e842b17d01e..f12152be4fd8 100644 --- a/pkg/cmd/roachtest/tests/logical_data_replication.go +++ b/pkg/cmd/roachtest/tests/logical_data_replication.go @@ -44,7 +44,7 @@ type ycsbWorkload struct { } func (ycsb ycsbWorkload) sourceInitCmd(tenantName string, nodes option.NodeListOption) string { - cmd := roachtestutil.NewCommand(`./cockroach workload init ycsb`). + cmd := roachtestutil.NewCommand(`./cockroach workload init ycsb --families=false`). MaybeFlag(ycsb.initRows > 0, "insert-count", ycsb.initRows). MaybeFlag(ycsb.initSplits > 0, "splits", ycsb.initSplits). Arg("{pgurl%s:%s}", nodes, tenantName) @@ -52,7 +52,7 @@ func (ycsb ycsbWorkload) sourceInitCmd(tenantName string, nodes option.NodeListO } func (ycsb ycsbWorkload) sourceRunCmd(tenantName string, nodes option.NodeListOption) string { - cmd := roachtestutil.NewCommand(`./cockroach workload run ycsb`). + cmd := roachtestutil.NewCommand(`./cockroach workload run ycsb --families=false`). Option("tolerate-errors"). Flag("workload", ycsb.workloadType). MaybeFlag(ycsb.debugRunDuration > 0, "duration", ycsb.debugRunDuration). diff --git a/pkg/sql/schemachanger/scbuild/internal/scbuildstmt/alter_table_alter_primary_key.go b/pkg/sql/schemachanger/scbuild/internal/scbuildstmt/alter_table_alter_primary_key.go index 10dad9fb7580..f8ecf900a704 100644 --- a/pkg/sql/schemachanger/scbuild/internal/scbuildstmt/alter_table_alter_primary_key.go +++ b/pkg/sql/schemachanger/scbuild/internal/scbuildstmt/alter_table_alter_primary_key.go @@ -71,7 +71,6 @@ func alterPrimaryKey(b BuildCtx, tn *tree.TableName, tbl *scpb.Table, t alterPri fallBackIfShardedIndexExists(b, t, tbl.TableID) fallBackIfPartitionedIndexExists(b, t, tbl.TableID) fallBackIfRegionalByRowTable(b, t.n, tbl.TableID) - fallBackIfDescColInRowLevelTTLTables(b, tbl.TableID, t) fallBackIfSubZoneConfigExists(b, t.n, tbl.TableID) inflatedChain := getInflatedPrimaryIndexChain(b, tbl.TableID) @@ -446,15 +445,6 @@ func fallBackIfRegionalByRowTable(b BuildCtx, t tree.NodeFormatter, tableID cati } } -// fallBackIfDescColInRowLevelTTLTables panics with an unimplemented -// error if the table is a (row-level-ttl table && (it has a descending -// key column || it has any inbound/outbound FK constraint)). -func fallBackIfDescColInRowLevelTTLTables(b BuildCtx, tableID catid.DescID, t alterPrimaryKeySpec) { - if _, _, rowLevelTTLElem := scpb.FindRowLevelTTL(b.QueryByID(tableID)); rowLevelTTLElem == nil { - return - } -} - func mustRetrieveCurrentPrimaryIndexElement( b BuildCtx, tableID catid.DescID, ) (res *scpb.PrimaryIndex) { diff --git a/pkg/workload/schemachange/operation_generator.go b/pkg/workload/schemachange/operation_generator.go index 4523e65240b3..5090a93fb252 100644 --- a/pkg/workload/schemachange/operation_generator.go +++ b/pkg/workload/schemachange/operation_generator.go @@ -182,7 +182,7 @@ func (og *operationGenerator) getSupportedDeclarativeOp( // stochastic attempts and if verbosity is >= 2 the unsuccessful attempts are // recorded in `log` to help with debugging of the workload. func (og *operationGenerator) randOp( - ctx context.Context, tx pgx.Tx, useDeclarativeSchemaChanger, allowDML bool, + ctx context.Context, tx pgx.Tx, useDeclarativeSchemaChanger bool, numOpsInTxn int, ) (stmt *opStmt, err error) { for { var op opType @@ -195,8 +195,11 @@ func (og *operationGenerator) randOp( } else { op = opType(og.params.ops.Int()) } - if !allowDML && isDMLOpType(op) { - continue + if numOpsInTxn != 1 { + // DML and legacy PK changes are only allowed in single-statement transactions. + if isDMLOpType(op) || (op == alterTableAlterPrimaryKey && !useDeclarativeSchemaChanger) { + continue + } } og.resetOpState(useDeclarativeSchemaChanger) @@ -2785,6 +2788,8 @@ func (og *operationGenerator) commentOn(ctx context.Context, tx pgx.Tx) (*opStmt SELECT 'INDEX ' || quote_ident(schema_name) || '.' || quote_ident(table_name) || '@' || quote_ident("index"->>'name') FROM indexes UNION ALL SELECT 'CONSTRAINT ' || quote_ident("constraint"->>'name') || ' ON ' || quote_ident(schema_name) || '.' || quote_ident(table_name) FROM constraints + -- Avoid temporary CHECK constraints created while adding NOT NULL columns. + WHERE "constraint"->>'name' NOT LIKE '%%auto_not_null' %s`, onType)) commentables, err := Collect(ctx, og, tx, pgx.RowTo[string], q) diff --git a/pkg/workload/schemachange/schemachange.go b/pkg/workload/schemachange/schemachange.go index f78515baf450..1488d80bb364 100644 --- a/pkg/workload/schemachange/schemachange.go +++ b/pkg/workload/schemachange/schemachange.go @@ -456,12 +456,12 @@ func (w *schemaChangeWorker) runInTxn( ) error { w.logger.startLog(w.id) w.logger.writeLog("BEGIN") - opsNum := 1 + w.opGen.randIntn(w.maxOpsPerWorker) - if useDeclarativeSchemaChanger && opsNum > w.workload.declarativeSchemaMaxStmtsPerTxn { - opsNum = w.workload.declarativeSchemaMaxStmtsPerTxn + numOps := 1 + w.opGen.randIntn(w.maxOpsPerWorker) + if useDeclarativeSchemaChanger && numOps > w.workload.declarativeSchemaMaxStmtsPerTxn { + numOps = w.workload.declarativeSchemaMaxStmtsPerTxn } - for i := 0; i < opsNum; i++ { + for i := 0; i < numOps; i++ { // Terminating this loop early if there are expected commit errors prevents unexpected commit behavior from being // hidden by subsequent operations. Consider the case where there are expected commit errors. // It is possible that committing the transaction now will fail the workload because the error does not occur @@ -474,8 +474,7 @@ func (w *schemaChangeWorker) runInTxn( break } - // Only allow DML for single-statement transactions. - op, err := w.opGen.randOp(ctx, tx, useDeclarativeSchemaChanger, opsNum == 1) + op, err := w.opGen.randOp(ctx, tx, useDeclarativeSchemaChanger, numOps) if pgErr := new(pgconn.PgError); errors.As(err, &pgErr) && pgcode.MakeCode(pgErr.Code) == pgcode.SerializationFailure { return errors.Mark(err, errRunInTxnRbkSentinel)