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

MySQLでリーチ行の値が高い列値の合計を選択するにはどうすればよいですか?


CASEステートメントを使用して、同じ条件を設定します。まずテーブルを作成しましょう-

mysql> create table DemoTable
   -> (
   -> X int,
   -> Y int
   -> );
Query OK, 0 rows affected (0.57 sec)

挿入コマンド-

を使用して、テーブルにいくつかのレコードを挿入します
mysql> insert into DemoTable values(20,30);
Query OK, 1 row affected (0.15 sec)

mysql> insert into DemoTable values(40,15);
Query OK, 1 row affected (0.14 sec)

mysql> insert into DemoTable values(80,85);
Query OK, 1 row affected (0.13 sec)

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

mysql> select *from DemoTable;

出力

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

+------+------+
| X    | Y    |
+------+------+
|   20 |   30 |
|   40 |   15 |
|   80 |   85 |
+------+------+
3 rows in set (0.00 sec)

以下は、各行で値が高い列値の合計を選択するためのクエリです。

mysql> SELECT SUM(CASE WHEN X > Y THEN X ELSE Y END) from DemoTable;

出力

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

+----------------------------------------+
| SUM(CASE WHEN X > Y THEN X ELSE Y END) |
+----------------------------------------+
|                                    155 |
+----------------------------------------+
1 row in set (0.00 sec)

  1. MySQLで対応する重複する列値を持つ列から最小行値を選択します

    まずテーブルを作成しましょう- mysql> create table DemoTable1875    (    Id int NOT NULL AUTO_INCREMENT PRIMARY KEY,    Class varchar(20),    Amount int ); Query OK, 0 rows affected (0.00 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> insert into DemoTable1875(Class

  2. MySQLで列が複数の値を満たす必要がある場合に行を選択するにはどうすればよいですか?

    このために、IN()とともにGROUPBYHAVING句を使用できます。まずテーブルを作成しましょう- mysql> create table DemoTable1885    (    FirstName varchar(20),    Subject varchar(50)    ); Query OK, 0 rows affected (0.00 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> insert into DemoTable1885 val