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

MySQLの集計関数と他のすべての列を選択します


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

mysql> create table DemoTable1621
    -> (
    -> StudentId int NOT NULL AUTO_INCREMENT PRIMARY KEY,
    -> StudentName varchar(20),
    -> StudentMarks int
    -> );
Query OK, 0 rows affected (1.69 sec)
>

挿入コマンド-

を使用して、テーブルにいくつかのレコードを挿入します
mysql> insert into DemoTable1621(StudentName,StudentMarks) values('Chris',45);
Query OK, 1 row affected (0.22 sec)
mysql> insert into DemoTable1621(StudentName,StudentMarks) values('Bob',78);
Query OK, 1 row affected (0.13 sec)
mysql> insert into DemoTable1621(StudentName,StudentMarks) values('David',89);
Query OK, 1 row affected (0.16 sec)
mysql> insert into DemoTable1621(StudentName,StudentMarks) values('Adam',87);
Query OK, 1 row affected (0.20 sec)

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

mysql> select * from DemoTable1621;

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

+-----------+-------------+--------------+
| StudentId | StudentName | StudentMarks |
+-----------+-------------+--------------+
|         1 | Chris       |           45 |
|         2 | Bob         |           78 |
|         3 | David       |           89 |
|         4 | Adam        |           87 |
+-----------+-------------+--------------+
4 rows in set (0.00 sec)

以下は、集計関数を選択するためのクエリです-

mysql> select tblData.*,( select max(StudentMarks) from DemoTable1621) as MaximumMarks from DemoTable1621 tblData;

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

+-----------+-------------+--------------+--------------+
| StudentId | StudentName | StudentMarks | MaximumMarks |
+-----------+-------------+--------------+--------------+
|         1 | Chris       |           45 |           89 |
|         2 | Bob         |           78 |           89 |
|         3 | David       |           89 |           89 |
|         4 | Adam        |           87 |           89 |
+-----------+-------------+--------------+--------------+
4 rows in set (0.00 sec)

  1. MySQLでグループ化して選択して合計しますか?

    合計するには、集計関数SUM()を使用します。それで、MySQLGROUPBYを使用してグループ化します。まずテーブルを作成しましょう- mysql> create table DemoTable    -> (    -> ProductName varchar(20),    -> ProductQuantity int,    -> ProductPrice int    -> ); Query OK, 0 rows affected (0.63 sec

  2. MySQLエントリが存在するかどうかを確認し、存在する場合は、他の列を上書きする方法を教えてください。

    これには、INSERT ON DUPLICATEKEYUPDATEコマンドを使用します。まずテーブルを作成しましょう- mysql> create table DemoTable1891    (    FirstName varchar(20),    UNIQUE KEY(FirstName)    ); Query OK, 0 rows affected (0.00 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> insert into DemoTab