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

MySQLの別の列で条件が満たされた場合に、列のセルを合計するにはどうすればよいですか?


このために、GROUP BY句とともに集計関数SUM()を使用できます。まずテーブルを作成しましょう-

mysql> create table DemoTable
   -> (
   -> EmployeeName varchar(20),
   -> JoiningDate date,
   -> Salary int
   -> );
Query OK, 0 rows affected (0.54 sec)

挿入コマンド-

を使用して、テーブルにいくつかのレコードを挿入します
mysql> insert into DemoTable values('David','2019-11-02',400);
Query OK, 1 row affected (0.52 sec)
mysql> insert into DemoTable values('Robert','2018-11-25',100);
Query OK, 1 row affected (0.39 sec)
mysql> insert into DemoTable values('Bob','2019-12-14',600);
Query OK, 1 row affected (0.25 sec)
mysql> insert into DemoTable values('Carol','2019-11-03',300);
Query OK, 1 row affected (0.23 sec)

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

mysql> select * from DemoTable;

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

+--------------+-------------+--------+
| EmployeeName | JoiningDate | Salary |
+--------------+-------------+--------+
| David        | 2019-11-02  |    400 |
| Robert       | 2018-11-25  |    100 |
| Bob          | 2019-12-14  |    600 |
| Carol        | 2019-11-03  |    300 |
+--------------+-------------+--------+
4 rows in set (0.00 sec)

別の列で条件が満たされた場合に、ある列のセルを合計するクエリは次のとおりです-

mysql> select year(JoiningDate) as JoiningYear,
   -> month(JoiningDate) as JoiningMonth,
   -> sum(Salary) as Total,
   -> group_concat(EmployeeName) as Name
   -> from DemoTable
   -> group by JoiningYear,JoiningMonth;

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

+-------------+--------------+-------+-------------+
| JoiningYear | JoiningMonth | Total | Name        |
+-------------+--------------+-------+-------------+
|        2018 |           11 |   100 | Robert      |
|        2019 |           11 |   700 | David,Carol |
|        2019 |           12 |   600 | Bob         |
+-------------+--------------+-------+-------------+
3 rows in set (0.04 sec)

  1. MySQLを使用してJavaでResultSetの列名を取得するにはどうすればよいですか?

    結果セットの列名を取得するには、getMetaData()メソッドを使用する必要があります。 getMetadata()のプロトタイプは次のとおりです- ResultSetMetaData getMetaData throws SQLException; 5つの列名を持つMySQLテーブルを作成します。テーブルを作成するためのクエリは次のとおりです- mysql> create table javagetallcolumnnames    -> (    -> Id int NOT NULL AUTO_INCREMENT,  

  2. MySQLで特定の列名を持つテーブルを見つける方法は?

    列名を見つけるには、information_schema.columnsを使用します。以下は構文です- select distinct table_name from information_schema.columns where column_name like '%yourSearchValue%' and table_schema=database(); さまざまなテーブルで列名を見つけるために、上記の構文を実装しましょう。ここでは、特定の列名が「クライアント」という単語を持つテーブル名のみが必要です- mysql> select distinct table_