MySQL
 Computer >> コンピューター >  >> プログラミング >> MySQL

現在使用しているものとは異なるデータベースにあるMySQLテーブルのリストと、結果セットのテーブルタイプを確認するにはどうすればよいですか?


SHOWFULLTABLESステートメントを使用して実行できます。その構文は次のようになります-

構文
SHOW FULL TABLES FROM db_name

ここでは、 db_name テーブルのリストを表示するデータベースの名前です。

現在、「query」という名前のデータベースを使用しています。以下のMySQLクエリは、mysqlという名前のデータベースのテーブルタイプとともにテーブルのリストを表示します。

mysql> SHOW FULL TABLES FROM mysql;
+---------------------------+------------+
| Tables_in_mysql           | Table_type |
+---------------------------+------------+
| arena                     | BASE TABLE |
| arena1                    | BASE TABLE |
| columns_priv              | BASE TABLE |
| dates                     | VIEW       |
| dates1                    | VIEW       |
| db                        | BASE TABLE |
| digits                    | VIEW       |
| engine_cost               | BASE TABLE |
| event                     | BASE TABLE |
| func                      | BASE TABLE |
| general_log               | BASE TABLE |
| gtid_executed             | BASE TABLE |
| help_category             | BASE TABLE |
| help_keyword              | BASE TABLE |
| help_relation             | BASE TABLE |
| help_topic                | BASE TABLE |
| innodb_index_stats        | BASE TABLE |
| innodb_table_stats        | BASE TABLE |
| ndb_binlog_index          | BASE TABLE |
| numbers                   | VIEW       |
| plugin                    | BASE TABLE |
| proc                      | BASE TABLE |
| procs_priv                | BASE TABLE |
| proxies_priv              | BASE TABLE |
| server_cost               | BASE TABLE |
| servers                   | BASE TABLE |
| slave_master_info         | BASE TABLE |
| slave_relay_log_info      | BASE TABLE |
| slave_worker_info         | BASE TABLE |
| slow_log                  | BASE TABLE |
| tables_priv               | BASE TABLE |
| test_date                 | BASE TABLE |
| time_zone                 | BASE TABLE |
| time_zone_leap_second     | BASE TABLE |
| time_zone_name            | BASE TABLE |
| time_zone_transition      | BASE TABLE |
| time_zone_transition_type | BASE TABLE |
| user                      | BASE TABLE |
+---------------------------+------------+
38 rows in set (0.01 sec)

  1. テーブルのリストでMySQL一時テーブルをどのように確認できますか?

    SHOW TABLESステートメントを使用すると、データベース内のテーブルのリストを確認できます。ただし、MySQL一時テーブルはこのリストに格納されていません。つまり、SHOWTABLESステートメントを使用して一時テーブルを表示することはできません。それを説明するために、次の例を使用しています- 例 この例では、次のようにSHOWTABLESステートメントから「SalesSummary」という名前の一時テーブルを取得しようとしています- mysql> SHOW TABLES LIKE '%Sales%'; Empty set (0.00 sec) mysql>

  2. INFORMATION_SCHEMA.TABLESを使用してMySQLを使用してデータベースにテーブルがすでに存在するかどうかを確認するにはどうすればよいですか?

    MySQLを使用してテーブルがデータベースにすでに存在するかどうかを確認するには、INFORMATION_SCHEMA.TABLESを使用できます。以下は構文です- SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = ‘yourDatabaseName’ AND TABLE_NAME = ’yourTableName’; テーブルがデータベースにすでに存在するかどうかを確認するために、上記の構文を実装しましょう。 ケース1 :テーブルが存在する場合- my