-
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
executor: replace should not change other rows when auto ID is out of range (#30301) #32324
executor: replace should not change other rows when auto ID is out of range (#30301) #32324
Conversation
Signed-off-by: ti-srebot <[email protected]>
[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. Reviewer can indicate their review by submitting an approval review. |
/run-all-tests |
@tangenta you're already a collaborator in bot's repo. |
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.
LGTM
/merge |
This pull request has been accepted and is ready to merge. Commit hash: 9705da4
|
/merge |
Code Coverage Details: https://codecov.io/github/pingcap/tidb/commit/7d3f33ec574b28d9e1ab2cc76203f2b33d080744 |
/merge |
1 similar comment
/merge |
/run-mysql-test |
1 similar comment
/run-mysql-test |
/run-unit-test |
/run-check_dev |
cherry-pick #30301 to release-5.3
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/32324
After apply modifications, you can push your change to this PR via:
What problem does this PR solve?
Issue Number: close #29483
Problem Summary:
Specifying a zero value for the auto_increment column triggers ID allocation. In the current implementation, the allocated ID will be replaced in the row which is equivalent to
Since 128 is out of range for
tinyint
column,128
is truncated to127
insetDatumAutoIDAndCast()
:However, these two REPLACE statements should be different because
0
case, it means adding a new row.127
case, it means updating an old row if exists.What is changed and how it works?
In this PR, I add a check inside
setDatumAutoIDAndCast()
to prevent a truncated auto-ID is used. The error message is different from MySQL's "duplicate primary key" because of the implementation difficulty: there is no way to tellReplaceExec
that whether the row is filled by auto-IDs without changing the interface.tidb/executor/replace.go
Line 192 in a046014
This can cause MySQL incompatibility when there is no duplicated auto-ID:
I think it is fine because this error can be an alert, reminding the users that auto-IDs are exhausted.
Check List
Tests
Side effects
Documentation
Release note