SHOW TABLEを使用せずにMySQLでテーブルのauto_increment値を表示しますか?
テーブルのauto_increment値を表示するには、INFORMATION_SCHEMA.TABLESを使用できます。
まずテーブルを作成しましょう-
mysql> create table viewtheauto_incrementValueForATableDemo -> ( -> StudentId int NOT NULL AUTO_INCREMENT PRIMARY KEY, -> StudentName varchar(20) -> ); Query OK, 0 rows affected (0.84 sec)
以下は、挿入コマンド-
を使用してテーブルにいくつかのレコードを挿入するためのクエリです。mysql> insert into viewtheauto_incrementValueForATableDemo(StudentName) values('Ramit'); Query OK, 1 row affected (0.23 sec) mysql> insert into viewtheauto_incrementValueForATableDemo(StudentName) values('Bob'); Query OK, 1 row affected (0.14 sec) mysql> insert into viewtheauto_incrementValueForATableDemo(StudentName) values('Chris'); Query OK, 1 row affected (0.15 sec) mysql> insert into viewtheauto_incrementValueForATableDemo(StudentName) values('Robert'); Query OK, 1 row affected (0.12 sec) mysql> insert into viewtheauto_incrementValueForATableDemo(StudentName) values('John'); Query OK, 1 row affected (0.46 sec)
以下は、selectステートメントを使用してテーブルのすべてのレコードを表示するためのクエリです-
mysql> select * from viewtheauto_incrementValueForATableDemo;
これにより、次の出力が生成されます-
+-----------+-------------+ | StudentId | StudentName | +-----------+-------------+ | 1 | Ramit | | 2 | Bob | | 3 | Chris | | 4 | Robert | | 5 | John | +-----------+-------------+ 5 rows in set (0.00 sec)
以下は、テーブルのauto_increment値を表示するためのクエリです-
mysql> SELECT `AUTO_INCREMENT` AS 'NextAutoIncrementValue' -> FROM `information_schema`.`TABLES` -> WHERE `TABLE_SCHEMA` = 'test' -> AND `TABLE_NAME` = 'viewtheauto_incrementValueForATableDemo';
これにより、次の出力が生成されます-
+------------------------+ | NextAutoIncrementValue | +------------------------+ | 6 | +------------------------+ 1 row in set (0.00 sec)
-
MySQLテーブルにない値をデータベースに照会しますか?
このために、WHERE NOTEXISTSとともにUNIONALLを使用し、NOT INを実装して、テーブルにすでに存在する値を無視することができます。 UNION ALLでSELECTを使用して、まだテーブルにない値を追加します。 まずテーブルを作成しましょう- mysql> create table DemoTable1918 ( Value int NOT NULL AUTO_INCREMENT PRIMARY KEY ); Query OK, 0 rows affected (0.00 sec) 挿
-
別のテーブルの値を使用したINSERTINTOのMySQLクエリ?
これには、INSERTINTOSELECTステートメントを使用します。 テーブルを作成しましょう- 例 mysql> create table demo82 -> ( -> id int, -> name varchar(20) -> ); Query OK, 0 rows affected (2.06 挿入コマンド-を使用して、いくつかのレコードをテーブルに挿入します。 例 mysql> insert into demo82 values(100,&