tencent cloud

TDSQL-C for MySQL

動向とお知らせ
製品アップデート
製品お知らせ
初心者ガイド
製品概要
プロダクト概要
製品の強み
適用シーン
製品アーキテクチャ
製品仕様
インスタンスタイプ
製品機能一覧
データベースのバージョン
リージョンとアベイラビリティゾーン
基本概念
利用制限
利用ガイドの推奨事項
自社開発カーネル
カーネル概要
カーネルバージョンのアップデート情報
カーネル最適化バージョン
機能特性
パフォーマンス関連機能
セキュリティカテゴリの機能
安定性機能
分析エンジン特性
カーネル問題のチェックと修復
購入ガイド
課金概要
製品価格
クラスタを作成する
構成変更説明
未払いについての説明
継続支払いの説明
返金ポリシー
従量課金から年/月単位サブスクリプションへの変換
従量課金からServerlessへの変換
付加価値サービスの課金説明
料金請求書の確認
クイックスタート
データベース監査
概要
監査インスタンス一覧
監査サービスを有効化する
監査ログの確認
ログ配信
事後アラーム設定
監査ルールの変更
監査サービスを変更する
監査サービスを停止する
監査ルールテンプレート
監査タスクの照会
サブユーザーへのデータベース監査利用権限付与
Serverlessサービス
Serverless入門
サーバーレス版クラスタの作成と管理
伸縮性スケーリング管理ツール
Serverlessリソースパック
マルチAZデプロイ
設定を変更する
よくあるご質問
Serverlessコスト見積ツール
操作ガイド
操作概要
コンソールでのクラスタページビューの切り替え
データベース接続
インスタンス管理
設定を変更する
インスタンス形態管理
クラスタ管理
読み取り専用インスタンス管理 
データベースプロキシ
アカウント管理
DMC
DMC(データベース管理ツール)
パラメータ設定
マルチAZデプロイ
グローバルデータベース
バックアップとリストア
操作ログ
データマイグレーション
パラレルクエリ
列ストレージインデックス CSI
分析エンジン
データベースセキュリティと暗号化
モニタリングとアラーム
SQLの基本操作
以下のコマンドを実行して、TDSQL-C for MySQLに接続してログインします
Tag
実践チュートリアル
TDSQL-C for MySQL データベース監査の等級保護実践
非InnoDBテーブル問題のワンクリック移行検出処理方法
DTSによるデータベースバージョンのアップグレード MySQL 5.7から8.0へ
TDSQL-C for MySQL 使用規範
新版コンソール
データベースプロキシの複数接続アドレスによる複数ROグループの実現
データベースプロキシのメリット
ストレージの課金モードの選び方
DTSによるリモートディザスタリカバリの構築
クラスタ用VPCの作成
データ復旧の方法
CPU使用率の高騰問題の解決方法
サブユーザーへの監視データ閲覧権限付与方法
ホワイトペーパー
セキュリティホワイトペーパー
性能ホワイトペーパー
トラブルシューティング
接続関連
性能関連
よくあるご質問
基本概念
購入と課金
サポートされるフォーマット
接続とネットワーク
機能特性
コンソールの操作
データベーステーブル
パフォーマンスとログ
データベース監査
TDSQL-C for MySQLとTencentDB for MySQLの違い
関連契約
SLA
利用規約
TDSQL-C ポリシー
プライバシーポリシー
データ処理と安全プロトコル
汎用参考
標準と認証
用語一覧
お問い合わせ

対応文と制限事項

PDF
フォーカスモード
フォントサイズ
最終更新日: 2025-12-30 16:46:22
本稿では、CSI (Column store Index) 列ストレージインデックス機能がサポートするステートメントと制限シナリオをご紹介します。

前提条件

カーネルバージョンは TDSQL-C for MySQL 8.0 バージョン3.1.14以上です。
説明:
読み取り専用インスタンスの場合、バージョン要件を満たす条件下で、4コア以上の読み取り専用インスタンスのみ列ストレージインデックス機能を有効化できます。

対応ステートメント

TDSQL-C for MySQL は、以下の特徴を備えた SQL文 のクエリプッシュダウン処理をすでに実現しました。そして、より多くの機能シナリオを徐々に充実させています。
機能シナリオ
説明
単一テーブルスキャン
単一テーブルスキャンにおいて、フルテーブルスキャン、インデックススキャン、インデックス範囲スキャンなどのスキャンタイプの順方向・逆方向スキャンをサポートしています。
複数テーブル join
複数テーブルジョインにおいて、ネステッドループジョイン、ハッシュジョイン、ソートマージジョインなどの多様なジョインアルゴリズムをサポートします。
サブクエリ
サブクエリにおいては、非相関サブクエリをサポートしています。
データ型
データ型に関しては、整数型データ、文字列型データ、浮動小数点型データ、日時型データなど、複数のデータ型を含むクエリをサポートします。
演算式
算術式演算(+、-、*、%、/、|、&)、条件式演算(<、<=、>、>=、<>、between and、In など)、論理演算(or、and、not など)、一般関数(文字列関数、整数関数、日付関数など)、集計関数(count/sum/avg/min/max など)をサポートします。
プッシュダウン実行計画を表示する
Explainによるプッシュダウン実行計画の表示をサポートしていますが、COLUMNSTOREマークはExplain format=treeでのみ表示されます。

機能制限

TDSQL-C for MySQLはCSIクエリ能力を継続的に強化していきます。現時点でCSIクエリが利用できないシナリオは次の通りです:

CSIの作成に関する制限

同一テーブルにはCSIインデックスを1つしか作成できません。
Generated Column、BLOB、TEXT、JSON、BIT、GEOMETRYを使用したCSIの作成はサポートされていません。
COPYアルゴリズムを使用したCSIの作成・削除、またはCSIを削除してから再追加する操作はサポートされていません。
InnoDB以外のテーブルではCSIの作成はサポートされていません。

CSIテーブルに対するDDL制限

CSIテーブルに対するパーティション操作はサポートされていません。

SELECTでのCSI使用の制限事項

DMLにおけるSELECT、INSERT ... SELECT/REPLACE ... SELECTはサポートしていません。
CTEはサポートされていません。
ウィンドウ関数はサポートされていません。
with rollupはサポートしていません。
UNIONはサポートされていません。
ReadCommit以外の分離レベルのトランザクションはサポートしていません。
ロック付き読み取りステートメント(例:SELECT FOR UPDATE/SHARE LOCKなど)はサポートしていません。
ストアドプロシージャはサポートされていません。
SQL_MODEのMODE_PAD_CHAR_TO_FULL_LENGTH/MODE_INVALID_DATESはサポートされていません。
GIS関連関数(例:SP_WITHIN_FUNC、st_distanceなど)はサポートしていません。
ユーザー定義関数はサポートしていません。
XML関連関数(xml_str)はサポートしていません。
ロック関連の関数(is_free_lock、is_used_lock、release_lock、release_all_locks、get_lock)はサポートしていません。

注意事項

CSIクエリと通常クエリの実行結果には一定の非互換性が存在し、以下の点が含まれます。
結果セット順序なし
列ストレージの編成方式はBTreeの編成方式と異なるため、ORDER序を指定しない場合、返される結果セットはBTR実行時の結果順序と一致しない可能性があります。実際、これはANSI標準に準拠していますが、ユーザーが結果セットの順序に敏感な場合は、シリアル実行と一致した結果を得るためにソートルールの指定を推奨します。
精度と切り捨て問題
CSIを使用する場合、一部のデータ型の保存と計算精度がMySQLと完全には一致しないため、浮動小数点部分で精度の差異が生じたり切り捨てが発生したりする可能性があり、最終結果にわずかな差異が生じることがあります。
エラーやアラームの表示回数が増える可能性があります
シリアル実行でエラー/アラームが発生するクエリに対して、CSIを使用した並列実行の場合、各ワーカスレッドがエラー/アラームを発生させる可能性があり、全体のエラー/アラーム発生回数が増加することがあります。
リソースの影響
CSIのバッファプールはシステムメモリ空間を占有します。
CSIの並列実行では、シリアルクエリのシングルスレッドモードに比べて、並列クエリはより多くのスレッド、メモリ、およびIOリソースを消費します。

ヘルプとサポート

この記事はお役に立ちましたか?

フィードバック