MySQLの最後の行を除くすべての行をテーブルから選択するにはどうすればよいですか?
サブクエリとともに!=演算子を使用する必要があります。構文は次のとおりです-
select *from yourTableName where yourIdColumnName != (select max(yourIdColumnName) from yourTableName );
上記の構文を理解するために、テーブルを作成しましょう。テーブルを作成するためのクエリは次のとおりです-
mysql> create table AllRecordsExceptLastOne -> ( -> Id int NOT NULL AUTO_INCREMENT, -> UserName varchar(10), -> UserAge int -> , -> PRIMARY KEY(Id) -> ); Query OK, 0 rows affected (0.65 sec)
これで、insertコマンドを使用してテーブルにいくつかのレコードを挿入できます。クエリは次のとおりです-
mysql> insert into AllRecordsExceptLastOne(UserName,UserAge) values('John',21); Query OK, 1 row affected (0.12 sec) mysql> insert into AllRecordsExceptLastOne(UserName,UserAge) values('Carol',28); Query OK, 1 row affected (0.18 sec) mysql> insert into AllRecordsExceptLastOne(UserName,UserAge) values('Mike',22); Query OK, 1 row affected (0.13 sec) mysql> insert into AllRecordsExceptLastOne(UserName,UserAge) values('Sam',29); Query OK, 1 row affected (0.14 sec) mysql> insert into AllRecordsExceptLastOne(UserName,UserAge) values('David',27); Query OK, 1 row affected (0.11 sec) mysql> insert into AllRecordsExceptLastOne(UserName,UserAge) values('Larry',24); Query OK, 1 row affected (0.20 sec)
selectステートメントを使用して、テーブルのすべてのレコードを表示します。クエリは次のとおりです-
mysql> select *from AllRecordsExceptLastOne;
以下は出力です-
+----+----------+---------+ | Id | UserName | UserAge | +----+----------+---------+ | 1 | John | 21 | | 2 | Carol | 28 | | 3 | Mike | 22 | | 4 | Sam | 29 | | 5 | David | 27 | | 6 | Larry | 24 | +----+----------+---------+ 6 rows in set (0.00 sec)
これは、最後の行を除くテーブルからすべての行を選択するためのクエリです-
mysql> select *from AllRecordsExceptLastOne where Id!=(select max(Id) from AllRecordsExceptLastOne);
以下は出力です-
+----+----------+---------+ | Id | UserName | UserAge | +----+----------+---------+ | 1 | John | 21 | | 2 | Carol | 28 | | 3 | Mike | 22 | | 4 | Sam | 29 | | 5 | David | 27 | +----+----------+---------+ 5 rows in set (0.04 sec)
-
MySQLのselectクエリを使用して、別のテーブルにないテーブルから行を選択しますか?
この例では、2つのテーブルを作成し、Natural Left Joinを適用して、2番目のテーブルに存在しないテーブルから行を取得します。 最初のテーブルを作成します。 mysql> create table FirstTableDemo -> ( -> id int, -> name varchar(100) -> ); Query OK, 0 rows affected (0.48 sec) 最初のテーブルにレコードを挿入します。 mysql> insert into FirstTableDemo values(1,Bo
-
MySQLから最後の10行を選択するにはどうすればよいですか?
MySQLから最後の10行を選択するには、SELECTステートメントとLimitの概念でサブクエリを使用できます。以下は例です。 テーブルを作成します。 mysql> create table Last10RecordsDemo -> ( -> id int, -> name varchar(100) -> ); Query OK, 0 rows affected (0.75 sec) テーブルにレコードを挿入します。 mysql> insert into Last10RecordsDemo values(1,John),(