MySQL ORDER BY xを実装する方法(col3!=nullの場合はx=col3、それ以外の場合はx =col2)?
これには、ORDER BY IFNULL()を使用できます。まずテーブルを作成しましょう-
mysql> create table DemoTable -> ( -> Name varchar(20), -> CountryName varchar(20) -> ); Query OK, 0 rows affected (0.61 sec)
挿入コマンド-
を使用して、テーブルにいくつかのレコードを挿入しますmysql> insert into DemoTable values('Chris',NULL); Query OK, 1 row affected (0.19 sec) mysql> insert into DemoTable values('David','AUS'); Query OK, 1 row affected (0.14 sec) mysql> insert into DemoTable values(NULL,'UK'); Query OK, 1 row affected (0.17 sec) mysql> insert into DemoTable values(NULL,'AUS'); Query OK, 1 row affected (0.10 sec) mysql> insert into DemoTable values(NULL,NULL); Query OK, 1 row affected (0.11 sec)
selectステートメントを使用してテーブルのすべてのレコードを表示する-
mysql> select *from DemoTable;
これにより、次の出力が生成されます-
+-------+-------------+ | Name | CountryName | +-------+-------------+ | Chris | NULL | | David | AUS | | NULL | UK | | NULL | AUS | | NULL | NULL | +-------+-------------+ 5 rows in set (0.00 sec)
これは、MySQL ORDER BY xを実装するためのクエリです。ここで(col3!=nullの場合はx=col3、それ以外の場合はx =col2)-
mysql> select *from DemoTable -> order by ifnull(Name,CountryName);
これにより、次の出力が生成されます-
+-------+-------------+ | Name | CountryName | +-------+-------------+ | NULL | NULL | | NULL | AUS | | Chris | NULL | | David | AUS | | NULL | UK | +-------+-------------+ 5 rows in set (0.00 sec)
-
MySQLでグループ化されたフィールドで並べ替える方法は?
グループ化されたフィールドをORDERBYするには、IN()とともにORDERBYCASEを使用します。 CASEはさまざまな条件を評価しますが、ORDERBYは値を昇順または降順で並べ替えます。 MySQL IN()は、一致するものを見つけるために使用されます。 まずテーブルを作成しましょう- mysql> create table DemoTable ( Value varchar(40) ); Query OK, 0 rows affected (0.52 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql>
-
MySQLでWHEREINnullを選択しますか?
以下は構文です- select yourColumnName1, yourColumnName2, yourColumnName3, . . . N from yourTableName where yourValue in(yourColumnName1,yourColumnName2) or yourColumnName1 is NULL; テーブルを作成しましょう- mysql> create table demo60 −> ( −> id int not null auto_increment primary key, −>