MySQLで別々のテキストの複数の出現をカウントしますか?
これには、if()とともに集計関数countを使用できます。概念を理解するために、テーブルを作成しましょう。テーブルを作成するためのクエリは次のとおりです
mysql> create table CountOccurrencesDemo -> ( -> Id int NOT NULL AUTO_INCREMENT PRIMARY KEY, -> TechnicalSubject varchar(100) -> ); Query OK, 0 rows affected (0.68 sec)
これで、insertコマンドを使用してテーブルにいくつかのレコードを挿入できます。クエリは次のとおりです
mysql> insert into CountOccurrencesDemo(TechnicalSubject) values('Java'); Query OK, 1 row affected (0.14 sec) mysql> insert into CountOccurrencesDemo(TechnicalSubject) values('MongoDB'); Query OK, 1 row affected (0.13 sec) mysql> insert into CountOccurrencesDemo(TechnicalSubject) values('MySQL'); Query OK, 1 row affected (0.16 sec) mysql> insert into CountOccurrencesDemo(TechnicalSubject) values('MySQL'); Query OK, 1 row affected (0.10 sec) mysql> insert into CountOccurrencesDemo(TechnicalSubject) values('MySQL'); Query OK, 1 row affected (0.07 sec) mysql> insert into CountOccurrencesDemo(TechnicalSubject) values('Java'); Query OK, 1 row affected (0.15 sec) mysql> insert into CountOccurrencesDemo(TechnicalSubject) values('Java'); Query OK, 1 row affected (0.10 sec) mysql> insert into CountOccurrencesDemo(TechnicalSubject) values('Java'); Query OK, 1 row affected (0.09 sec) mysql> insert into CountOccurrencesDemo(TechnicalSubject) values('Java'); Query OK, 1 row affected (0.11 sec) mysql> insert into CountOccurrencesDemo(TechnicalSubject) values('MongoDB'); Query OK, 1 row affected (0.21 sec)
selectステートメントを使用して、テーブルのすべてのレコードを表示します。クエリは次のとおりです
mysql> select *from CountOccurrencesDemo;
以下は出力です
+----+------------------+ | Id | TechnicalSubject | +----+------------------+ | 1 | Java | | 2 | MongoDB | | 3 | MySQL | | 4 | MySQL | | 5 | MySQL | | 6 | Java | | 7 | Java | | 8 | Java | | 9 | Java | | 10 | MongoDB | +----+------------------+ 10 rows in set (0.00 sec)
以下は、MySQLでのテキストの複数の出現をカウントするためのクエリです
mysql> select count(if(tbl.TechnicalSubject LIKE '%Java%',1,null)) as JavaOccurrence, -> count(if(tbl.TechnicalSubject LIKE '%MySQL%',1,null)) as MySQLOccurrence, -> count(if(tbl.TechnicalSubject LIKE '%MongoDB%',1,null)) as MongoDBOccurrence -> from CountOccurrencesDemo tbl;
以下は出力です
+----------------+-----------------+-------------------+ | JavaOccurrence | MySQLOccurrence | MongoDBOccurrence | +----------------+-----------------+-------------------+ | 5 | 3 | 2 | +----------------+-----------------+-------------------+ 1 row in set (0.05 sec)
-
MySQLの複数のテーブルから行をカウント(*)しますか?
MySQLで複数のテーブルの行をカウントするには、構文は次のとおりです- Select (select count(*) from yourTableName1) as anyAliasName1, (select count(*) from yourTableName2) as anyAliasName2 from dual; まずテーブルを作成しましょう- mysql> create table DemoTable1 -> ( -> I
-
特定の列値の単一のMySQLクエリで複数のカウントを取得する
このために、特定の列のパラメーター値とともに集計関数sum()を使用できます。まずテーブルを作成しましょう- mysql> create table DemoTable1790 ( Id int NOT NULL AUTO_INCREMENT PRIMARY KEY, Name varchar(20), Score int ); Query OK, 0 rows affected (0.94