diff --git a/pkg/sql/copy/BUILD.bazel b/pkg/sql/copy/BUILD.bazel index a587b7e314dc..6aa12567a4dd 100644 --- a/pkg/sql/copy/BUILD.bazel +++ b/pkg/sql/copy/BUILD.bazel @@ -13,6 +13,7 @@ go_test( shard_count = 4, deps = [ "//pkg/base", + "//pkg/ccl", "//pkg/cli/clisqlclient", "//pkg/kv", "//pkg/kv/kvclient/kvcoord", diff --git a/pkg/sql/copy/copy_test.go b/pkg/sql/copy/copy_test.go index a2033131e58e..a626aae7b0a5 100644 --- a/pkg/sql/copy/copy_test.go +++ b/pkg/sql/copy/copy_test.go @@ -22,6 +22,7 @@ import ( "github.com/cockroachdb/apd/v3" "github.com/cockroachdb/cockroach/pkg/base" + "github.com/cockroachdb/cockroach/pkg/ccl" "github.com/cockroachdb/cockroach/pkg/cli/clisqlclient" "github.com/cockroachdb/cockroach/pkg/kv" "github.com/cockroachdb/cockroach/pkg/kv/kvserver/kvserverbase" @@ -84,6 +85,7 @@ const csvData = `%d|155190|7706|1|17|21168.23|0.04|0.02|N|O|1996-03-13|1996-02-1 func TestDataDriven(t *testing.T) { defer leaktest.AfterTest(t)() + defer ccl.TestingEnableEnterprise()() // allow usage of READ COMMITTED ctx := context.Background() doTest := func(t *testing.T, d *datadriven.TestData, conn clisqlclient.Conn) string { diff --git a/pkg/sql/copy/testdata/copy_to_read_committed b/pkg/sql/copy/testdata/copy_to_read_committed new file mode 100644 index 000000000000..98715239c753 --- /dev/null +++ b/pkg/sql/copy/testdata/copy_to_read_committed @@ -0,0 +1,27 @@ +# Verify that the default transaction isolation level is applied to the +# internal queries issued by the COPY command. +exec-ddl +SET default_transaction_isolation = 'read committed' +---- + +copy-to +COPY (SELECT current_setting('transaction_isolation')) TO STDOUT +---- +read committed + +copy-to +COPY (SELECT 1, 2, 3) TO STDOUT +---- +1 2 3 + +copy-to +COPY ( + SELECT repeat('a' || i::STRING, 5), repeat('b' || i::STRING, 5) + FROM ROWS FROM (generate_series(1, 5)) AS i +) TO STDOUT; +---- +a1a1a1a1a1 b1b1b1b1b1 +a2a2a2a2a2 b2b2b2b2b2 +a3a3a3a3a3 b3b3b3b3b3 +a4a4a4a4a4 b4b4b4b4b4 +a5a5a5a5a5 b5b5b5b5b5 diff --git a/pkg/sql/copy_to.go b/pkg/sql/copy_to.go index f83c537cc442..d71dcdef6e46 100644 --- a/pkg/sql/copy_to.go +++ b/pkg/sql/copy_to.go @@ -181,10 +181,10 @@ func runCopyTo( }).String() } - it, err := p.execCfg.InternalDB.NewInternalExecutor(p.SessionData()).QueryIteratorEx( + it, err := p.InternalSQLTxn().QueryIteratorEx( ctx, cmd.Stmt.String(), - txn, + p.Txn(), sessiondata.NoSessionDataOverride, q, ) diff --git a/pkg/sql/isql/isql_db.go b/pkg/sql/isql/isql_db.go index 5c4a3d2a874f..35bce4b1b6cf 100644 --- a/pkg/sql/isql/isql_db.go +++ b/pkg/sql/isql/isql_db.go @@ -262,9 +262,6 @@ type Rows interface { // Types returns the types of the columns returned by this iterator. The // returned array is guaranteed to correspond 1:1 with the tree.Datums rows // returned by Cur(). - // - // WARNING: this method is safe to call anytime *after* the first call to - // Next() (including after Close() was called). Types() colinfo.ResultColumns // HasResults returns true if there are results to the query, false otherwise.