MySQLはライブラリ内の主キーなしでテーブルインスタンスコードを素早く取得します

MySQLはライブラリ内の主キーなしでテーブルインスタンスコードを素早く取得します

概要

MySQL データベースで主キーのないテーブルを表示するための SQL ステートメントをいくつかまとめてみましょう。見てみましょう。

1. テーブルの主キー情報を表示する

--テーブルの主キー情報を表示するSELECT
 t.テーブル名、
 t.制約タイプ、
 c.列名、
 c.ORDINAL_POSITION 
から
 INFORMATION_SCHEMA.TABLE_CONSTRAINTS AS t、
 INFORMATION_SCHEMA.KEY_COLUMN_USAGE AS c 
どこ
 t.テーブル名 = c.テーブル名 
 かつ t.CONSTRAINT_TYPE = 'PRIMARY KEY' 
 AND t.TABLE_NAME = '<TABLE_NAME>' 
 AND t.TABLE_SCHEMA = '<TABLE_SCHEMA>'; 


2. 主キーなしでテーブルを表示する

--主キーなしでテーブルを表示する SELECT table_schema, table_name,TABLE_ROWS
information_schema.tables から
WHERE (テーブルスキーマ、テーブル名) NOT IN (
SELECT DISTINCT テーブルスキーマ、テーブル名
information_schema.columns から
COLUMN_KEY = 'PRI' の場合
)
AND table_schema は ('sys'、'mysql'、'information_schema'、'performance_schema') に含まれません。 


3. 主キーのないテーブル

Innodb ストレージ エンジンでは、各テーブルに主キーがあり、データは主キーの順序で整理され、保存されます。このタイプのテーブルは、インデックス構成テーブルと呼ばれます。

テーブルの定義時に主キーが明示的に定義されていない場合、主キーは次のように選択または作成されます。

1) まず、テーブルに「空でない一意のインデックス」があるかどうかを確認します。ある場合は、

「空でない一意のインデックス」が1つだけの場合、このインデックスが主キーになります。

「空でない一意のインデックス」が複数ある場合は、インデックスの順序に従って、最初に定義された空でない一意のインデックスが主キーとして選択されます。

2) テーブル内に「空でない一意のインデックス」がない場合、6 バイトのポインタが主キーとして自動的に作成されます。

主キー インデックスにインデックス キーが 1 つしかない場合は、_rowid を使用して主キーを表示できます。実験テストは次のとおりです。

--テストテーブルを削除します。DROP TABLE IF EXISTS t1;
​
--テストテーブルを作成する CREATE TABLE `t1` (
 `id` int(11) NULLではない、
 `c1` int(11) デフォルト NULL,
 ユニーク uni_id (ID)、
 インデックスidx_c1(c1)
)ENGINE = InnoDB CHARSET = utf8;
​
--テストデータを挿入します INSERT INTO t1 (id, c1) SELECT 1, 1;
t1 (id, c1) に挿入し、2, 2 を選択します。
t1 (id, c1) に挿入し、4, 4 を選択します。
​
--データと_rowidを表示する
t1から*、_rowidを選択します。 


id 列はテーブル内の最初の一意かつ NOT NULL インデックスであるため、上記の _rowid は id の値と同じであることがわかります。

要約する

以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。

以下もご興味があるかもしれません:
  • 不足している主キーテーブル情報を取得するための MYSQL ステートメント

<<:  vue3 のさまざまな構文形式を比較したサンプルコード

>>:  Centos6.6 で php7 + nginx 環境をインストールする方法

推薦する

Linuxでのcrontabの使い方と注意点の詳しい説明

Crontab は定期的な実行を設定するために使用されるコマンドです。そのデーモン プロセスは cr...

Vue3でカルーセルコンポーネントをカプセル化する方法

目的カルーセルコンポーネントをカプセル化して直接使用します。具体的な内容は以下のとおりです。一般的な...

ウェブサイトに最も必要なのは、ターゲットユーザーグループのエクスペリエンスを向上させることです。

「大河は東に流れ、波は歴代の英雄たちを洗い流した。古城の西側は三国時代の周朗の赤壁だと言われている...

docker-compose ネットワーク設定についての簡単な説明

ネットワーク使用チュートリアル公式サイト docker-compose.yml リファレンスドキュメ...

mysqld_multi を使用して単一のマシンに複数のインスタンスをデプロイする方法に関する MySQL チュートリアル

目次1. MySQLのコンパイルとインストール: 2. 最初のマルチインスタンス3307を準備する3...

JavaScript のシングルトン デザイン パターン

目次1. デザインパターンとは何ですか? 2. デザインパターンの5つの設計原則(SOLID) 3....

MySQL の null (IFNULL、COALESCE、NULLIF) に関する知識ポイントのまとめ

この記事では、MySQL の null (IFNULL、COALESCE、NULLIF) に関連する...

Windows Server 2012 リモート デスクトップ ライセンス サーバーがライセンスを提供できず、リモート セッションが切断される

本日、会社の内部サーバーにログインしたところ、リモートアクセスができませんでした。エラー メッセージ...

Mysql データベースの高度なビュー、トランザクション、インデックス、自己接続、ユーザー管理の例の分析の使用

この記事では、ビュー、トランザクション、インデックス、自己接続、ユーザー管理など、MySQL データ...

MySQL サーバーの接続、切断、および cmd 操作

mysql コマンドを使用して MySQL サーバーに接続します。 MySQL サーバーが起動したら...

MySQL で単一のデータベースまたはテーブルを復元する方法と、起こりうる落とし穴

序文:最も一般的に使用される MySQL 論理バックアップ ツールは mysqldump です。通常...

Dockerプライベート倉庫の構築と利用の詳細説明

イメージは hub.docker.com に保存できますが、ネットワーク速度が比較的遅いです。内部環...

Ubuntu の Docker で mysql5.6 をインストールする方法

1. mysql5.6をインストールする docker 実行 mysql:5.6すべてのアイテムのダ...

vue3 watch と watchEffect の使い方と違い

1.リスナーを見る時計のご紹介 'vue' から { ref, reactive, ...