execution: fix the incorrect use of cached plan for point get (#24749)#24765
Conversation
Signed-off-by: ti-srebot <ti-srebot@pingcap.com>
|
/run-all-tests |
|
@cfzjywxk please accept the invitation then you can push to the cherry-pick pull requests. |
|
/lgtm |
|
[REVIEW NOTIFICATION] This pull request has been approved by:
To complete the pull request process, please ask the reviewers in the list to review by filling The full list of commands accepted by this bot can be found here. DetailsReviewer can indicate their review by writing |
|
/merge |
|
This pull request has been accepted and is ready to merge. DetailsCommit hash: a153d25 |
|
/merge |
|
@ti-srebot: Your PR was out of date, I have automatically updated it for you. At the same time I will also trigger all tests for you: /run-all-tests If the CI test fails, you just re-trigger the test that failed and the bot will merge the PR for you after the CI passes. DetailsInstructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the ti-community-infra/tichi repository. |
cherry-pick #24749 to release-5.0
You can switch your code base to this Pull Request by using git-extras:
# In tidb repo: git pr https://github.com/pingcap/tidb/pull/24765After apply modifications, you can push your change to this PR via:
Signed-off-by: cfzjywxk lsswxrxr@163.com
What problem does this PR solve?
Issue Number: close #24741
Problem Summary:
The point get cached plan is used incorrectly for the in transaction prepare execution statement, which may change the transaction to invalid status unexpectedly and lead to panic or incorrect read.
What is changed and how it works?
What's Changed:
Use the
autocommitTxnjudge logic instead ofautocommit.How it Works:
The autocommit mode flag and the in txn flag are different. In the
IsCachedExecOklogic, only autocommit primary key point get read could use the cached plan.Related changes
Check List
Tests
Side effects
Release note