-
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
statistics: batch insert topn and bucket when saving table stats #35326
statistics: batch insert topn and bucket when saving table stats #35326
Conversation
[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. |
Code Coverage Details: https://codecov.io/github/pingcap/tidb/commit/48ba2f0dd321b3c8e06e3a2a2a49066780e0c9ef |
/merge |
This pull request has been accepted and is ready to merge. Commit hash: d501085
|
/run-mysql-test |
Signed-off-by: ti-srebot <[email protected]>
cherry pick to release-4.0 in PR #35544 |
Signed-off-by: ti-srebot <[email protected]>
cherry pick to release-5.0 in PR #35545 |
Signed-off-by: ti-srebot <[email protected]>
cherry pick to release-5.1 in PR #35546 |
Signed-off-by: ti-srebot <[email protected]>
cherry pick to release-5.2 in PR #35547 |
Signed-off-by: ti-srebot <[email protected]>
cherry pick to release-5.3 in PR #35548 |
Signed-off-by: ti-srebot <[email protected]>
cherry pick to release-5.4 in PR #35549 |
Signed-off-by: ti-srebot <[email protected]>
cherry pick to release-6.0 in PR #35550 |
Signed-off-by: ti-srebot <[email protected]>
cherry pick to release-6.1 in PR #35551 |
TiDB MergeCI notify🔴 Bad News! [1] CI still failing after this pr merged.
|
* upstream/master: sessionctx: support encoding and decoding session variables (pingcap#35531) planner: add batch_point_get access object (pingcap#35230) sessionctx: set skipInit false for TiDBOptProjectionPushDown and TiDBOptAggPushDown (pingcap#35491) *: add support for disabling noop variables (pingcap#35496) lightning: add store write limiter (pingcap#35193) expression: avoid padding 0 when implicitly cast to binary (pingcap#35053) types: fix creating partition tables fail in ANSI_QUOTES mode (pingcap#35379) executor: add the missed runtime stats when the index merge partial task returns 0 row (pingcap#35297) statistics: batch insert topn and bucket when saving table stats (pingcap#35326) parser: Add support for INTERVAL expr unit + expr (pingcap#30253) (pingcap#35390) config: add missing nodelay example (pingcap#35255) *: Introduce `OptimisticTxnContextProvider` for optimistic txn (pingcap#35131) statistics: fix panic when using wrong globalStats.Indices key (pingcap#35424) *: fix store token is up to the limit in test (pingcap#35374) *: enable more flaky and update bazel config (pingcap#35500) ddl: expose getPrimaryKey() as a public method of model.TableInfo (pingcap#35512) expression, util: add `KeyWithoutTrimRightSpace` for collator (pingcap#35475) infoschema: try on each PD member until one succeeds or all fail (pingcap#35285)
What problem does this PR solve?
Issue Number: ref #35142
Problem Summary:
Analyze partition table is slower than analyze non-partition table with the same amount of data.
What is changed and how it works?
In
SaveTableStatsToStorage
, we execute one insert statement for each topn and each bucket so there are too many insertions in the transaction and make the function time-consuming. The PR batches insertions for topn and bucket and makeSaveTableStatsToStorage
more efficient.Check List
Tests
For a table with 40 million rows and 20 partitions, analyze takes 9min and
SaveTableStatsToStorage
for one partition takes 21s. After the PR, analyze takes 3min andSaveTableStatsToStorage
for one partition takes 4s.Side effects
Documentation
Release note
Please refer to Release Notes Language Style Guide to write a quality release note.