- TiDBについて
- クイックスタート
- 発展させる
- 概要
- クイックスタート
- TiDB Cloud(開発者層) で TiDB クラスターを構築する
- TiDB の CRUD SQL
- TiDB でシンプルな CRUD アプリを構築する
- 応用例
- TiDB に接続する
- データベース スキーマの設計
- 書き込みデータ
- データの読み取り
- 取引
- 最適化
- トラブルシューティング
- 参照
- 書店のサンプル アプリケーション
- ガイドライン
- アーカイブされたドキュメント
- クラウドネイティブ開発環境
- サードパーティのサポート
- デプロイ
- 移行する
- 管理
- 監視と警告
- トラブルシューティング
- TiDB トラブルシューティング マップ
- 遅いクエリを特定する
- 遅いクエリを分析する
- SQL 診断
- Top SQLを使用して高価なクエリを特定する
- ログを使用して高価なクエリを特定する
- ステートメント要約表
- ホットスポットの問題のトラブルシューティング
- 増加した読み取りおよび書き込み遅延のトラブルシューティング
- クラスターのオンサイト情報の保存と復元
- クラスタ セットアップのトラブルシューティング
- 高いディスク I/O 使用率のトラブルシューティング
- ロック競合のトラブルシューティング
- TiFlash のトラブルシューティング
- オプティミスティック トランザクションでの書き込み競合のトラブルシューティング
- データとインデックス間の不一致のトラブルシューティング
- 性能チューニング
- チューニングガイド
- Configuration / コンフィグレーションのチューニング
- システムのチューニング
- ソフトウェアのチューニング
- Configuration / コンフィグレーション
- コプロセッサ キャッシュ
- SQL チューニング
- チュートリアル
- TiDB ツール
- 概要
- ユースケース
- ダウンロード
- TiUP
- ドキュメンテーション マップ
- 概要
- 用語と概念
- TiUP コンポーネントの管理
- FAQ
- トラブルシューティングガイド
- コマンドリファレンス
- 概要
- TiUP コマンド
- TiUP クラスタ コマンド
- 概要
- tiup cluster audit
- tiup cluster check
- tiup cluster clean
- tiup cluster deploy
- tiup cluster destroy
- tiup cluster disable
- tiup cluster display
- tiup cluster edit-config
- tiup cluster enable
- tiup cluster help
- tiup cluster import
- tiup cluster list
- tiup cluster patch
- tiup cluster prune
- tiup cluster reload
- tiup cluster rename
- tiup cluster replay
- tiup cluster restart
- tiup cluster scale-in
- tiup cluster scale-out
- tiup cluster start
- tiup cluster stop
- tiup cluster template
- tiup cluster upgrade
- TiUP DMコマンド
- TiDB クラスター トポロジ リファレンス
- DM クラスタ トポロジ リファレンス
- ミラー リファレンス ガイド
- TiUP コンポーネント
- PingCAPクリニック診断サービス
- TiDB Operator
- Dumpling
- TiDB Lightning
- TiDB データ移行
- バックアップと復元 (BR)
- Binlog
- TiCDC
- Dumpling
- 同期差分インスペクター
- ティスパーク
- 参照
- クラスタ アーキテクチャ
- 主な監視指標
- セキュリティ
- 権限
- SQL
- SQL 言語の構造と構文
- SQL ステートメント
ADD COLUMN
ADD INDEX
ADMIN
ADMIN CANCEL DDL
ADMIN CHECKSUM TABLE
ADMIN CHECK [TABLE|INDEX]
ADMIN SHOW DDL [JOBS|QUERIES]
ADMIN SHOW TELEMETRY
ALTER DATABASE
ALTER INDEX
ALTER INSTANCE
ALTER PLACEMENT POLICY
ALTER TABLE
ALTER TABLE COMPACT
ALTER USER
ANALYZE TABLE
BACKUP
BATCH
BEGIN
CHANGE COLUMN
COMMIT
CHANGE DRAINER
CHANGE PUMP
CREATE [GLOBAL|SESSION] BINDING
CREATE DATABASE
CREATE INDEX
CREATE PLACEMENT POLICY
CREATE ROLE
CREATE SEQUENCE
CREATE TABLE LIKE
CREATE TABLE
CREATE USER
CREATE VIEW
DEALLOCATE
DELETE
DESC
DESCRIBE
DO
DROP [GLOBAL|SESSION] BINDING
DROP COLUMN
DROP DATABASE
DROP INDEX
DROP PLACEMENT POLICY
DROP ROLE
DROP SEQUENCE
DROP STATS
DROP TABLE
DROP USER
DROP VIEW
EXECUTE
EXPLAIN ANALYZE
EXPLAIN
FLASHBACK TABLE
FLUSH PRIVILEGES
FLUSH STATUS
FLUSH TABLES
GRANT <privileges>
GRANT <role>
INSERT
KILL [TIDB]
LOAD DATA
LOAD STATS
MODIFY COLUMN
PREPARE
RECOVER TABLE
RENAME INDEX
RENAME TABLE
REPLACE
RESTORE
REVOKE <privileges>
REVOKE <role>
ROLLBACK
SELECT
SET DEFAULT ROLE
SET [NAMES|CHARACTER SET]
SET PASSWORD
SET ROLE
SET TRANSACTION
SET [GLOBAL|SESSION] <variable>
SHOW ANALYZE STATUS
SHOW [BACKUPS|RESTORES]
SHOW [GLOBAL|SESSION] BINDINGS
SHOW BUILTINS
SHOW CHARACTER SET
SHOW COLLATION
SHOW [FULL] COLUMNS FROM
SHOW CONFIG
SHOW CREATE PLACEMENT POLICY
SHOW CREATE SEQUENCE
SHOW CREATE TABLE
SHOW CREATE USER
SHOW DATABASES
SHOW DRAINER STATUS
SHOW ENGINES
SHOW ERRORS
SHOW [FULL] FIELDS FROM
SHOW GRANTS
SHOW INDEX [FROM|IN]
SHOW INDEXES [FROM|IN]
SHOW KEYS [FROM|IN]
SHOW MASTER STATUS
SHOW PLACEMENT
SHOW PLACEMENT FOR
SHOW PLACEMENT LABELS
SHOW PLUGINS
SHOW PRIVILEGES
SHOW [FULL] PROCESSSLIST
SHOW PROFILES
SHOW PUMP STATUS
SHOW SCHEMAS
SHOW STATS_HEALTHY
SHOW STATS_HISTOGRAMS
SHOW STATS_META
SHOW STATUS
SHOW TABLE NEXT_ROW_ID
SHOW TABLE REGIONS
SHOW TABLE STATUS
SHOW [FULL] TABLES
SHOW [GLOBAL|SESSION] VARIABLES
SHOW WARNINGS
SHUTDOWN
SPLIT REGION
START TRANSACTION
TABLE
TRACE
TRUNCATE
UPDATE
USE
WITH
- データ型
- 関数と演算子
- クラスタ化インデックス
- 制約
- 生成された列
- SQL モード
- テーブル属性
- 取引
- ガベージ コレクション (GC)
- ビュー
- パーティショニング
- 一時テーブル
- キャッシュされたテーブル
- 文字セットと照合順序
- SQL の配置規則
- システム テーブル
mysql
- 情報_スキーマ
- 概要
ANALYZE_STATUS
CLIENT_ERRORS_SUMMARY_BY_HOST
CLIENT_ERRORS_SUMMARY_BY_USER
CLIENT_ERRORS_SUMMARY_GLOBAL
CHARACTER_SETS
CLUSTER_CONFIG
CLUSTER_HARDWARE
CLUSTER_INFO
CLUSTER_LOAD
CLUSTER_LOG
CLUSTER_SYSTEMINFO
COLLATIONS
COLLATION_CHARACTER_SET_APPLICABILITY
COLUMNS
DATA_LOCK_WAITS
DDL_JOBS
DEADLOCKS
ENGINES
INSPECTION_RESULT
INSPECTION_RULES
INSPECTION_SUMMARY
KEY_COLUMN_USAGE
METRICS_SUMMARY
METRICS_TABLES
PARTITIONS
PLACEMENT_POLICIES
PROCESSLIST
REFERENTIAL_CONSTRAINTS
SCHEMATA
SEQUENCES
SESSION_VARIABLES
SLOW_QUERY
STATISTICS
TABLES
TABLE_CONSTRAINTS
TABLE_STORAGE_STATS
TIDB_HOT_REGIONS
TIDB_HOT_REGIONS_HISTORY
TIDB_INDEXES
TIDB_SERVERS_INFO
TIDB_TRX
TIFLASH_REPLICA
TIKV_REGION_PEERS
TIKV_REGION_STATUS
TIKV_STORE_STATUS
USER_PRIVILEGES
VIEWS
METRICS_SCHEMA
- UI
- TiDB ダッシュボード
- 概要
- 管理
- アクセス
- 概要ページ
- クラスター情報ページ
- Top SQLページ
- キー ビジュアライザー ページ
- メトリクス関係グラフ
- SQL ステートメントの分析
- スロークエリページ
- クラスタ診断
- 検索ログ ページ
- インスタンスのプロファイリング
- セッションの管理とConfiguration / コンフィグレーション
- FAQ
- CLI
- コマンド ライン フラグ
- Configuration / コンフィグレーションファイルのパラメーター
- システム変数
- ストレージ エンジン
- テレメトリー
- エラーコード
- テーブル フィルター
- トポロジ ラベルごとにレプリカをスケジュールする
- よくある質問
- リリースノート
- すべてのリリース
- リリースのタイムライン
- TiDB のバージョニング
- v6.1
- v6.0
- v5.4
- v5.3
- v5.2
- v5.1
- v5.0
- v4.0
- v3.1
- v3.0
- v2.1
- v2.0
- v1.0
- 用語集
重要
このページは英語版のページを機械翻訳しています。原文はこちらからご覧ください。
TiDB3.0.2リリースノート
発売日:2019年8月7日
TiDBバージョン:3.0.2
TiDB Ansibleバージョン:3.0.2
TiDB
- SQLオプティマイザー
- 同じテーブルがクエリで複数回発生し、論理的にクエリ結果が常に空である場合に「スキーマに列が見つかりません」というメッセージが報告される問題を修正します#11247
TIDB_INLJ
ヒントが正しく機能しない場合(explain select /*+ TIDB_INLJ(t1) */ t1.b, t2.a from t t1, t t2 where t1.b = t2.a
など)が原因でクエリプランが期待を満たさないという問題を修正します#11362- クエリ結果の列名が間違っている場合がある(
SELECT IF(1,c,c) FROM t
など)問題を修正します#11379 LIKE
式が暗黙的に0に変換される場合があるため、SELECT 0 LIKE 'a string'
などの一部のクエリがTRUE
を返す問題を修正します#11411SHOW COLUMNS FROM tbl WHERE FIELDS IN (SELECT 'a')
#11459のように、SHOW
ステートメントでサブクエリをサポートします- 集計関数の関連する列が見つからず、
outerJoinElimination
の最適化ルールが列エイリアスを正しく処理しないためにエラーが報告されるという問題を修正します。最適化プロセスでのエイリアス解析を改善して、最適化がより多くのクエリタイプをカバーできるようにします#11377 - ウィンドウ関数で構文制限に違反した場合にエラーが報告されない問題を修正します(たとえば、フレーム定義の最後に
UNBOUNDED PRECEDING
を表示することは許可されていません) #11543 - MySQL #11535との非互換性を引き起こす、
ERROR 3593 (HY000): You cannot use the window function FUNCTION_NAME in this context
エラーメッセージのFUNCTION_NAME
が大文字であるという問題を修正します。 - Window関数で実装されていない
IGNORE NULLS
構文が使用されているが、エラーが報告されないという問題を修正します#11593 - オプティマイザーが時間と等しい条件を正しく推定しない問題を修正します#11512
- フィードバック情報に基づくTop-N統計の更新をサポート#11507
- SQL実行エンジン
INSERT
関数のパラメーター#11248にNULL
が含まれている場合、戻り値がNULL
にならない問題を修正します。ADMIN CHECKSUM
操作#11266でパーティションテーブルをチェックすると、計算結果が間違っている可能性がある問題を修正します。- INDEXJOINがプレフィックスインデックス#11246を使用すると結果が間違っている可能性がある問題を修正します
DATE_ADD
関数がマイクロ秒#11288を含む日付番号で減算を行うときに、分数を誤って整列することによって結果が間違っている可能性があるという問題を修正します。DATE_ADD
関数が#11325の負の数を誤って処理することによって引き起こされる間違った結果を修正しINTERVAL
Mod(%)
、またはMultiple(*)
が0を返し、小数桁の数が多い(Minus(-)
など) #11251 、Mod(%)
、またはMultiple(*)
によって返される小数桁の数がMySQLの場合と異なる問題を修正しMinus(-)
select 0.000 % 0.11234500000000000000
CONCAT
関数とCONCAT_WS
関数によって返される結果の長さが#11275を超えると、警告付きのNULL
が誤って返される問題を修正しmax_allowed_packet
。SUBTIME
およびADDTIME
関数のパラメーターが無効な場合に警告付きのNULL
が誤って返される問題を修正します#11337CONVERT_TZ
関数のパラメーターが無効な場合にNULL
が誤って返される問題を修正します#11359EXPLAIN ANALYZE
によって返される結果にMEMORY
列を追加して、このクエリのメモリ使用量を示します#11418- #11429の結果に
CARTESIAN
結合を追加しEXPLAIN
- float型とdouble型の自動インクリメント列の誤ったデータを修正します#11385
- 疑似統計がダンプされたときにいくつかの情報によって引き起こされるpanicの問題を修正し#11460
nil
- 定数畳み込みの最適化によって引き起こされる
SELECT … CASE WHEN … ELSE NULL ...
の誤ったクエリ結果を修正します#11441 floatStrToIntStr
が#11473などの入力を正しく解析しない問題を修正し+999.9999e2
DATE_ADD
とDATE_SUB
の関数の結果がオーバーフローしたときにNULL
が返されない場合があるという問題を修正します#11476- 長い文字列を整数#11469に変換するときに文字列に無効な文字が含まれていると、変換結果がMySQLの結果と異なる問題を修正します。
- この関数の大文字と小文字の区別が原因で、
REGEXP BINARY
関数の結果がMySQLと互換性がないという問題を修正します#11504 GRANT ROLE
ステートメントがCURRENT_ROLE
を受け取ったときにエラーが報告される問題を修正します。REVOKE ROLE
ステートメントがmysql.default_role
特権を正しく取り消さないという問題を修正します#11356SELECT ADDDATE('2008-01-34', -1)
のようなステートメントを実行するときのIncorrect datetime value
警告情報の表示形式の問題を修正し#11447た- JSONデータのfloatフィールドが整数#11534に変換されたときに結果がオーバーフローした場合、エラーメッセージが
constant … overflows bigint
ではなくconstant … overflows float
を報告する問題を修正します。 DATE_ADD
関数がFLOAT
、およびDOUBLE
列パラメーターを受け取ったときに誤った型変換が原因で結果が間違っている可能性があるという問題を修正し#11527DECIMAL
DATE_ADD
関数#11615のINTERVAL分数の符号を誤って処理することによって引き起こされる誤った結果を修正します。Ranger
がプレフィックスインデックス#11565を正しく処理しないために発生したプレフィックスインデックスがインデックスルックアップ結合に含まれている場合の、誤ったクエリ結果を修正します。NAME_CONST
の2番目のパラメーターが負の数#11268のときにNAME_CONST
関数が実行されると、「NAME_CONSTへの引数が正しくありません」というメッセージが報告される問題を修正します。- SQLステートメントに現在時刻の計算が含まれ、値が複数回フェッチされる場合、結果がMySQLと互換性がないという問題を修正します。同じSQLステートメントの現在時刻をフェッチするときに同じ値を使用する#11394
baseExecutor
つのうちClose
がエラーを報告したときに、Close
がChildExecutor
に対して呼び出されないという問題を修正します。この問題は、KILL
のステートメントが有効にならず、ChildExecutor
が閉じられていない場合、Goroutineリークにつながる可能性があります#11576
- サーバ
LOAD DATA
がCSVファイル#11250の欠落しているTIMESTAMP
フィールドを処理するときに、自動追加値が現在のタイムスタンプではなく0になる問題を修正します。SHOW CREATE USER
ステートメントが関連する特権を正しくチェックせず、SHOW CREATE USER CURRENT_USER()
によって返されるUSER
とHOST
が間違っている可能性があるという問題を修正します#11229- JDBC #11290で
executeBatch
を使用すると、返される結果が間違っている可能性があるという問題を修正します。 - TiKVサーバーのポートを変更するときにストリーミングクライアントのログ情報の印刷を減らす#11370
- ストリーミングクライアントをTiKVサーバーに再接続するロジックを最適化して、ストリーミングクライアントが長期間ブロックされないようにします#11372
INFORMATION_SCHEMA.TIDB_HOT_REGIONS
にREGION_ID
を#11350- PD APIからリージョン情報を取得するタイムアウト期間をキャンセルして、リージョン数が多い場合のPDタイムアウトが原因で
http://{TiDBIP}:10080/regions/hot
が呼び出されたときにリージョン情報の取得が失敗しないようにします#11383 - リージョン関連のリクエストがHTTPAPI1でパーティション化されたテーブル関連のリージョンを返さない問題を修正し#11466
- ユーザーがペシミスティックロックを手動で検証するときに、操作が遅いためにロックタイムアウトが発生する可能性を減らすために、次の変更を行います#11521 :
- ペシミスティックロックのデフォルトTTLを30秒から40秒に増やします
- 最大TTLを60秒から120秒に増やします
- 最初の
LockKeys
のリクエストから悲観的なロック期間を計算します
- TiKVクライアントの
SendRequest
の機能ロジックを変更します。接続を確立できないときに待機するのではなく、すぐに別のピアに接続してみてください#11531 - リージョンキャッシュの最適化:別のストアが同じアドレスでオンラインになっているときにストアが移動された場合、削除されたストアに無効のラベルを付けて、キャッシュ内のストア情報をできるだけ早く更新します#11567
http://{TiDB_ADDRESS:TIDB_IP}/mvcc/key/{db}/{table}/{handle}
によって返される結果にリージョンIDを追加し#11557- ScatterTableAPIがRangeキーをエスケープしないためにScatterTableが機能しない問題を修正します#11298
- リージョンキャッシュを最適化する:コレスポンデントストアにアクセスできない場合、リージョンが存在するストアに無効のラベルを付けて、このストアへのアクセスによるクエリパフォーマンスの低下を回避します#11498
- 同じ名前のデータベースを複数回ドロップした後でも、HTTPAPIを介してテーブルスキーマを取得できるというエラーを修正します#11585
- DDL
- 長さがゼロの非文字列列にインデックスが付けられているときにエラーが発生する問題を修正します#11214
- 外部キー制約とフルテキストインデックスを使用した列の変更を禁止します(注:TiDBは、構文で外部キー制約とフルテキストインデックスを引き続きサポートします) #11274
ALTER TABLE
ステートメントによって変更された位置と列のデフォルト値が同時に使用されるため、列のインデックスオフセットが間違っている可能性がある問題を修正します#11346- JSONファイルの解析時に発生する2つの問題を修正します。
- 自動インクリメント列が誤った結果を取得する可能性を回避するために、自動インクリメント列へのインデックスの削除を禁止します#11399
- 次の問題を修正します#11492 :
- 照合順序を明示的に指定する場合、文字セットと列の照合順序は一貫していませんが、文字セットは指定していません
ALTER TABLE … MODIFY COLUMN
で指定された文字セットと照合順序の間に競合がある場合、エラーは正しく報告されません。ALTER TABLE … MODIFY COLUMN
を使用して文字セットと照合を複数回指定する場合のMySQLとの非互換性
- サブクエリのトレースの詳細を
TRACE
のクエリの結果に追加します#11458 - 実行
ADMIN CHECK TABLE
のパフォーマンスを最適化し、実行時間を大幅に短縮します#11547 SPLIT TABLE … REGIONS/INDEX
によって返された結果を追加し、TOTAL_SPLIT_REGION
とSCATTER_FINISH_RATIO
に、タイムアウト前に正常に分割されたリージョンの数を結果#11484に表示させます。ON UPDATE CURRENT_TIMESTAMP
が列属性であり、浮動小数点精度が指定されている場合、SHOW CREATE TABLE
などのステートメントによって表示される精度が不完全であるという問題を修正します#11591- 仮想生成列の式に別の仮想生成列が含まれている場合、列のインデックス結果を正しく計算できない問題を修正します#11475
ALTER TABLE … ADD PARTITION …
ステートメント#11581のVALUE LESS THAN
の後にマイナス記号を追加できない問題を修正します。
- モニター
TiKV
- Raftログが時間#5160に書き込まれない場合、TiKVがパニックになるバグを修正します。
- TiKVパニック後にpanic情報がログファイルに書き込まれないバグを修正します#5198
- 悲観的なトランザクションで挿入操作が正しく実行されない可能性があるバグを修正します#5203
- INFO1への手動介入を必要としない一部のログの出力レベルを下げ#5193
- ストレージエンジンのサイズ#5200の監視の精度を向上させる
- tikv-ctl1のリージョンサイズの精度を向上させ#5195
- 悲観的ロックのデッドロック検出器のパフォーマンスを向上させる#5192
- TitanストレージエンジンのGCのパフォーマンスを向上させる#5197
PD
- 散布リージョンスケジューラが機能しないバグを修正します#1642
- pd- #1653でリージョンのマージ操作を実行できないバグを修正します。
- pd- #1651でtombstoneの削除操作を実行できないバグを修正しました
- リージョンのスキャン操作を実行すると、キースコープと重複するリージョンが見つからない問題を修正します#1648
- 再試行メカニズムを追加して、メンバーがPD1に正常に追加されていることを確認し#1643
ツール
TiDB Binlog
- 起動時に構成アイテムチェック機能を追加します。これにより、 Binlogサービスが停止し、無効なアイテムが見つかったときにエラーが報告されます#687
- Drainerに
node-id
の構成を追加して、 Drainerで使用される特定のロジックを指定し#684
TiDB Lightning
- 2つのチェックサムが同時に実行されているときに
tikv_gc_life_time
が元の値に戻されないという問題を修正します#218 - 起動時に構成アイテムチェック機能を追加します。これにより、 Binlogサービスが停止し、無効なアイテムが見つかったときにエラーが報告されます#217
TiDB Ansible
- ディスクパフォーマンスモニターが秒をミリ秒として扱う単位エラーを修正#840
- Spark3に
log4j
の構成ファイルを追加し#841 - Binlogが有効で、KafkaまたはZooKeeperが構成されている場合に、Prometheus構成ファイルが間違った形式で生成される問題を修正します#844
- 生成されたTiDB構成ファイル#850で
pessimistic-txn
構成パラメーターが省略される問題を修正します。 - TiDBダッシュボード#853でメトリックを追加および最適化する
- TiDBダッシュボードに各監視項目の説明を追加する#854
- TiDBサマリーダッシュボードを追加して、クラスタステータスをより適切に表示し、問題のトラブルシューティングを行います#855
- TiKVダッシュボード#857のアロケータ統計監視項目を更新します。
- ノードエクスポータのアラート式#860のユニットエラーを修正します。
- TiSparkjarパッケージを#862にアップグレードします。
- Ansibleタスク機能の説明を更新する#867
- TiDBダッシュボード#874のローカルリーダーリクエスト監視項目の式を更新します。
- 概要ダッシュボードのTiKVメモリ監視項目の表現を更新し、誤って表示される監視の問題を修正します#879
- KafkaモードでBinlogサポートを削除する#878
rolling_update.yml
操作の実行時にPDがリーダーの転送に失敗する問題を修正します#887
このページの内容