-
Notifications
You must be signed in to change notification settings - Fork 3.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
sql: ensure a Prepare referencing a table created in the same txn works #14619
Conversation
Review status: 0 of 3 files reviewed at latest revision, 1 unresolved discussion, some commit checks pending. pkg/sql/executor.go, line 457 at r2 (raw file):
I'll do another review later, but at the very least this set needs to go up in the Comments from Reviewable |
Review status: 0 of 3 files reviewed at latest revision, 1 unresolved discussion, some commit checks failed. pkg/sql/executor.go, line 457 at r2 (raw file): Previously, jordanlewis (Jordan Lewis) wrote…
Done. Comments from Reviewable |
I think this fix is not enough we also need to update txnState.txn when we create the new transaction Review status: 0 of 3 files reviewed at latest revision, 1 unresolved discussion. Comments from Reviewable |
Added another commit for Review status: 0 of 3 files reviewed at latest revision, 1 unresolved discussion. Comments from Reviewable |
Review status: 0 of 3 files reviewed at latest revision, 2 unresolved discussions, some commit checks pending. pkg/sql/executor.go, line 451 at r5 (raw file):
I'm not sure this PR fully addresses @andreimatei's TODO. As I understand it his TODO also refers to the broader problem of using a prepared statement in a completely different transaction: BEGIN;
CREATE TABLE t (a int, b int);
COMMIT;
BEGIN;
PREPARE query AS SELECT a + b from t;
COMMIT;
BEGIN;
ALTER TABLE DROP COLUMN a;
ALTER TABLE ADD COLUMN a string;
COMMIT;
BEGIN;
EXECUTE query; -- ?!?
COMMIT; But I could be totally off base. Comments from Reviewable |
Review status: 0 of 3 files reviewed at latest revision, 2 unresolved discussions, some commit checks pending. pkg/sql/executor.go, line 451 at r5 (raw file): Previously, benesch (Nikhil Benesch) wrote…
I've added a comment about what txn this prepare needs to use. I believe it should be okay now. It needs to only pick up a txn if it already existed, and if one doesn't exist it can make a new txn to pick up a new lease. If future statements do not use the same txn that's okay. The particular code segment you wrote up is a broader problem where the prepare gets type checked against a much older table version. I haven't tried your example out because we don't actually support PREPARE as a first class SQL request, it's part of the pg wire protocol used for placeholder queries. Comments from Reviewable |
panic(err) | ||
txn := session.TxnState.txn | ||
if txn == nil { | ||
// The new txn need not be the same transaction used by statements following |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If it doesn't need to be the same, then why ever make it the same? Why is this change necessary exactly?
I think that this is the opposite of what we generally want to do; I think we want to always obtain leases in a fresh transaction - otherwise what's preventing us from obtaining a lease at an arbitrarily old version of a descriptor? (i.e. a client txn that's been lingering for a while might not see new versions of the descriptor... unless its attempt to write a lease at an old version is guaranteed to conflict with reads that will have been performed in the process of incrementing the descriptor version...).
There's some subtleties here I'm not currently sure of.
If you don't mind, I'd like to talk to you about our lease philosophy more. But I'm just boarding the plane for this California meetup.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree we have #6774 . Feel free to add more of your concerns to that issue and let's not block this PR.
The reason why the entire leasing mechanism takes an external transaction is only for the purposes of supporting INSERT after CREATE TABLE.
See this comment:
https://github.com/cockroachdb/cockroach/blob/master/pkg/sql/lease.go#L155
Review status: 0 of 3 files reviewed at latest revision, 3 unresolved discussions, all commit checks successful. pkg/sql/executor.go, line 451 at r5 (raw file): Previously, vivekmenezes wrote…
👍 sounds like that TODO was referencing #6774, but it wasn't the right place to do so. Thanks for clarifying! Comments from Reviewable |
Reviewed 1 of 1 files at r1, 2 of 2 files at r3, 2 of 2 files at r6. pkg/sql/pgwire/pgwire_test.go, line 464 at r6 (raw file):
You should actually execute the result of this prepare as well, I think, to ensure that it works as well. Comments from Reviewable |
Review status: 1 of 3 files reviewed at latest revision, 3 unresolved discussions, some commit checks pending. pkg/sql/pgwire/pgwire_test.go, line 464 at r6 (raw file): Previously, jordanlewis (Jordan Lewis) wrote…
Done. Comments from Reviewable |
Reviewed 2 of 2 files at r7, 2 of 2 files at r8, 2 of 2 files at r9. Comments from Reviewable |
Review status: all files reviewed at latest revision, 2 unresolved discussions, all commit checks successful. pkg/sql/executor.go, line 451 at r6 (raw file): Previously, vivekmenezes wrote…
Well I was thinking that another idea for dealing with tables created in the current txn is to maintain a list of descriptors in the txnState. It's nice because you don't actually need a lease to operate on these, just a descriptor. Comments from Reviewable |
Review status: all files reviewed at latest revision, 2 unresolved discussions, all commit checks successful. pkg/sql/executor.go, line 451 at r6 (raw file): Previously, andreimatei (Andrei Matei) wrote…
Don't quite follow what you mean but I've always hated the fact that you need to pass in a txn into the leasing logic. Comments from Reviewable |
rolls back cockroachdb#15339 cockroachdb#14368 for the most part and cockroachdb#14619 partially. We used a very big hammer to prevent some statements from following a schema change. This was done to reduce surprises but it ended up introducing more surprises. ORMs and schema migration tools depend on multiple schema changes being staged in the same transaction. fixes cockroachdb#15269
This change isdata:image/s3,"s3://crabby-images/d0bb7/d0bb7f7625ca5bf5c3cf7a2b7a514cf841ab8395" alt="Reviewable"