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

MySQLで更新を実行して、特定の値を超えるすべての値の増分を禁止するにはどうすればよいですか?


最初にテーブルを作成しましょう-

mysql> create table DemoTable
   -> (
   -> Value int
   -> );
Query OK, 0 rows affected (0.54 sec)

挿入コマンド-

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

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

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

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

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

mysql> select *from DemoTable;

出力

+-------+
| Value |
+-------+
|   100 |
|   150 |
|   180 |
|   200 |
+-------+
4 rows in set (0.00 sec)

以下は、MySQLの最大値を更新するためのクエリです-

mysql> set @value:=45;
Query OK, 0 rows affected (0.00 sec)

mysql> update DemoTable
-> set Value = LEAST(value + @value, 200) ;
Query OK, 3 rows affected (0.21 sec)
Rows matched: 4  Changed: 3 Warnings: 0

テーブルレコードをもう一度確認しましょう-

mysql> select *from DemoTable;

出力

これにより、次の出力が生成されます。ここでは、値を200-

より大きくすることを禁止しています。
+-------+
| Value |
+-------+
|   145 |
|   195 |
|   200 |
|   200 |
+-------+
4 rows in set (0.00 sec)

  1. MySQLの特定の値に対して低い値のレコード以外のレコードを選択するにはどうすればよいですか?

    このためには、WHERE句を使用する必要があります。以下は構文です- select *from yourTableName where yourColumnName > yourValue; テーブルを作成しましょう- mysql> create table demo27 −> ( −> id int not null auto_increment primary key, −> value int −> ); Query OK, 0 rows affected (3.14 sec) 挿入コマンド-を使用し

  2. MySQLで特定の値を持つ列の数を数える方法は?

    以下は構文です- select sum(yourColumnName1+yourColumnName2+yourColumnName3...N) as `anyAliasName1`, sum(yourColumnName1 and yourColumnName2 and yourColumnName3….N) as anyAliasName from yourTableName; テーブルを作成しましょう- mysql> create table demo36 −> ( −> id int not null auto_incremen