-
Notifications
You must be signed in to change notification settings - Fork 5.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
planner: check schema stale for plan cache when forUpdateRead #22381
Merged
Merged
Changes from 8 commits
Commits
Show all changes
16 commits
Select commit
Hold shift + click to select a range
e140977
add case
you06 996274a
add logs
you06 04ad7bb
add case and fix plan cache
you06 aad17ee
remove debug logs
you06 fc76fd9
Merge branch 'master' into plan-cache
AilinKid 1d6a1e5
fix binary protocol
you06 b18384f
fix plan cache not hit
you06 3d30f1a
Merge branch 'master' into plan-cache
you06 6fb982d
format imports
you06 daa5b08
Merge branch 'master' into plan-cache
you06 068b447
Merge branch 'master' into plan-cache
you06 e65a430
Merge branch 'master' into plan-cache
you06 6876428
fix default config change
you06 d939a00
update go.mod
you06 5702b0e
Merge branch 'master' into plan-cache
you06 fe31054
Merge branch 'master' into plan-cache
ti-chi-bot File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -198,4 +198,5 @@ type CachedPrepareStmt struct { | |
NormalizedPlan string | ||
SQLDigest string | ||
PlanDigest string | ||
ForUpdateRead bool | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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.
When use binary protocol and the plan cache is not hit, a new cache will generate inside
getPhysicalPlan
function, in which use the following codes to excludeTiFlash
engine for write statement.tidb/planner/optimize.go
Lines 85 to 88 in 2364fec
After the plan is builing complete, the
TiFlash
engine is set back and the it'll still write a plan-cache key withTiFlash
engine. As a result, we cache a write plan forTiFlash
engine, and it'll never be used correctly.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.
😮 @winoros PTAL