SHOW CREATE TABLE posts;
以上のコマンドですが どんなときに使用するのでしょうか
よろしくお願いいたします。
mysql> SHOW CREATE TABLE posts;
+-------+------------------------------+
| Table | Create Table |
+-------+-----------------+
| posts | CREATE TABLE `posts` (
`message_id` int(11) NOT NULL AUTO_INCREMENT,
`message` text,
`created_by` int(11) DEFAULT NULL,
`created` datetime NOT NULL,
`modified` datetime NOT NULL,
PRIMARY KEY (`message_id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4 |
+-------+---+
1 row in set (0.00 sec)
No.2ベストアンサー
- 回答日時:
RDBMSは表、インデックスなどの様々な定義情報を管理しています。
表やインデックスなどの定義内容を、後から確認したいということは普通にありますよね。
それらの定義情報は、ディクショナリやシステムカタログなどRDBMSにより呼び名や管理方式、管理情報が異なりますが、利用者が参照できる仕組みが提供されています。
標準SQL準拠でMySQLでも実装されているのが、情報スキーマ(INFORMATION_SCHEMA)です。各RDBMSにより管理する資源や方式が違うものを、共通のテーブル名、列名などで得られるようにしたもので、SQLのSELECT文で情報を得ることができます。
例えば定義されている表名を知りたい時、その方法は各RDBMSの独自命令を使う必要があります。
しかし、今日では標準SQL準拠の多くのRDBMSで、INFORMATION_SCHEMAのTABLES表をSQLのSELECT文で得られるようになっています。
https://dev.mysql.com/doc/refman/8.0/ja/informat …
ただし、各列に入っている内容は表名や列名などの基本的な項目以外は、各RDBMSの独自の管理情報であったりします。
SHOW文は、MySQLの定義情報を確認することができる独自機能です。
https://dev.mysql.com/doc/refman/8.0/ja/show.html
SHOW CREATE TABLEは、CREATE TABLEの定義内容を確認できる命令です。
単純にどのように定義したか確認するだけでなく、省略時解釈で使用する文字コード、ストレージエンジンなどが意図したものではない場合もあります。
そういった場合に、知っていて使うと便利な機能です。
再度ご回答下さいましてありがとうございました。
SHOW TABLES;
では
テーブルしか出てきませんが
mysql> SHOW CREATE TABLE posts;
とすると テーブル構造が分かりますね
何か調べるにはとてもいいコマンドだと
思います。ご回答を
全部読みましたが、詳しいことは実際に
開発などに携わらないと、専門的なので
私のレベルからして理解できない領域です。
今後ともよろしくお願いいたします。
No.3
- 回答日時:
MySQLでは未実装の機能をエラーにせず、解釈を変えて定義は通すということが伝統的に行われてきています。
例えば、以下の表定義では主キーが複数列で構成され、昇順と降順が混在しています。
CREATE TABLE t1
(c1 INT
,c2 VARCHAR(10)
,c3 DEC(5)
,PRIMARY KEY(c1,c2 DESC))
;
MySQL 5.7まではエラーになりませんが、内部的に定義変更され
PRIMARY KEY(c1,c2)
のように、すべて昇順に変更されて定義されます。
これらを確認するのにも、SHOW CREATE TABLEは必要な機能です。
No.1
- 回答日時:
ご回答ありがとうございました。
ディー‐ディー‐エル【DDL】
《data definition language》
ですね
テーブル構造が 見れますね。
今後ともよろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- MySQL my_itemsテーブルのIDにAUTO_INCREMENT を追加ができるかで 1 2023/01/03 09:09
- MySQL `picture` varchar(255) のコマンドで間違いないでしょうか? 1 2022/11/21 04:08
- MySQL MySQLのテーブル作成で 自信がありません。 2 2022/08/28 05:35
- MySQL エラー 1068 (42000): 複数の主キーが定義されていますエラー 2 2022/11/17 04:36
- MySQL MYSQL エラー 2 2022/10/18 11:37
- MySQL テーブル作成です。どこかのスペルが間違っているか記号など スペースかな? 1 2022/10/01 05:08
- MySQL PHPとMySQLを使った掲示板の作り方 1 2022/06/02 13:00
- PHP php テーブルが作成できない 1 2022/11/17 23:41
- MySQL php テーブルを作れない 2 2022/11/17 18:22
- MySQL あと、MySQLの文字コードはutf8 気になりますね 1 2022/12/01 07:22
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
VIEWの元のテーブルのindexって...
-
insertを高速化させたい
-
副問合せの書き方について
-
SQL Left Join で重複を排除す...
-
ある条件の最大値+1を初番する...
-
selectした大量データをinsert...
-
マイクラPC版のコマンドで効率...
-
select文のwhere句に配列を入れ...
-
一つ前のレコードの値と減算し...
-
my_itemsテーブルのIDにAUTO_IN...
-
期間の重複を調べるSQL文につい...
-
1対多結合で多を絞り込み条件と...
-
SELECT~LIKE~の結果が変
-
1テーブル&複数レコードの更新...
-
MySQLにてCOUNTした値を更にCOUNT
-
エクセルの関数について教えて...
-
Unionした最後にGROUP BYを追加...
-
SQLサーバから、項目の属性(型...
-
バインド変数について
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで最後の文字だけ置き...
-
SQL Left Join で重複を排除す...
-
VIEWの元のテーブルのindexって...
-
SQLサーバから、項目の属性(型...
-
select文のwhere句に配列を入れ...
-
副問合せの書き方について
-
マイクラPC版のコマンドで効率...
-
Unionした最後にGROUP BYを追加...
-
selectした大量データをinsert...
-
SQLにて特定の文字を除いた検索...
-
[SQLServer] テーブル名からカ...
-
1テーブル&複数レコードの更新...
-
inner joinをすると数がおかし...
-
クエリ表示と、ADOで抽出したレ...
-
ある条件の最大値+1を初番する...
-
sqlで、600行あるテーブルを100...
-
複数テーブルのGROUP BY の使い...
-
insertを高速化させたい
-
PL/SQLの変数について
-
キー毎の、ある列のmaxのレコー...
おすすめ情報