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

MySQLで重複する値のペアを見つける方法は?


MySQLで重複する値のペアを見つけるには、GROUPBYHAVING句を使用します。

まずテーブルを作成しましょう-

mysql> create table DemoTable748 (Id int, FirstName varchar(100));
Query OK, 0 rows affected (0.46 sec)

挿入コマンド-

を使用して、テーブルにいくつかのレコードを挿入します
mysql> insert into DemoTable748 values(100,'John');
Query OK, 1 row affected (0.10 sec)
mysql> insert into DemoTable748 values(100,'Sam');
Query OK, 1 row affected (0.12 sec)
mysql> insert into DemoTable748 values(200,'Carol');
Query OK, 1 row affected (0.10 sec)
mysql> insert into DemoTable748 values(200,'Carol');
Query OK, 1 row affected (0.13 sec)
mysql> insert into DemoTable748 values(300,'Mike');
Query OK, 1 row affected (0.17 sec)
mysql> insert into DemoTable748 values(300,'Sam');
Query OK, 1 row affected (0.15 sec)
>

selectステートメントを使用してテーブルのすべてのレコードを表示する-

mysql> select *from DemoTable748;

これにより、次の出力が生成されます-

+------+-----------+
| Id   | FirstName |
+------+-----------+
|  100 | John      |
|  100 | Sam       |
|  200 | Carol     |
|  200 | Carol     |
|  300 | Mike      |
|  300 | Sam       |
+------+-----------+
6 rows in set (0.00 sec)

以下は、MySQLで重複する値のペアを見つけるためのクエリです-

mysql> select Id from DemoTable748
   group by Id,FirstName having count(*)=2;

これにより、次の出力が生成されます。 IdとFirstNameの重複する値のペアは200のみであるため、出力には同じ-

が表示されます。
+------+
| Id   |
+------+
| 200  | 
+------+
1 row in set (0.00 sec)

  1. MySQLのデフォルト値をNONEに設定するにはどうすればよいですか?

    MySQLでデフォルト値を設定するには、DEFAULTキーワードを使用する必要があります。まずテーブルを作成しましょう- mysql> create table DemoTable (    ClientCountryName varchar(100) DEFAULT 'NONE' ); Query OK, 0 rows affected (0.65 sec) 挿入時に入力されなかった値には、上記のDEFAULTを設定しました。次に、insertコマンドを使用してテーブルにいくつかのレコードを挿入しましょう。一部の行の値はここに挿入されていません。

  2. MySQLを使用して一連の列でnull値を持つレコードを検索する方法

    これには、GREATEST()の概念を使用します。まずテーブルを作成しましょう- mysql> create table DemoTable1862      (      Value1 int,      Value2 int,      Value3 int,      Value4 int      ); Query OK, 0 rows affected (0.00 sec) 挿入コマンド-を使用して