MySQLに単一のクエリでブールフィールドを逆にする方法はありますか?
はい、MySQLのif()関数を使用して、ブールフィールドを逆にすることができます。構文は次のとおりです-
UPDATE yourTableName SET yourBooleanColumnName = IF(yourBooleanColumnName,0,1);
上記の構文を理解するために、テーブルを作成しましょう。テーブルを作成するためのクエリは次のとおりです-
mysql> create table ReverseBooleanField -> ( -> Id int NOT NULL AUTO_INCREMENT, -> isValid BOOLEAN -> , -> PRIMARY KEY(Id) -> ); Query OK, 0 rows affected (0.56 sec)>
これで、insertコマンドを使用してテーブルにいくつかのレコードを挿入できます。クエリは次のとおりです-
mysql> insert into ReverseBooleanField(isValid) values(true); Query OK, 1 row affected (0.18 sec) mysql> insert into ReverseBooleanField(isValid) values(false); Query OK, 1 row affected (0.14 sec) mysql> insert into ReverseBooleanField(isValid) values(true); Query OK, 1 row affected (0.29 sec) mysql> insert into ReverseBooleanField(isValid) values(true); Query OK, 1 row affected (0.09 sec) mysql> insert into ReverseBooleanField(isValid) values(false); Query OK, 1 row affected (0.14 sec)
selectステートメントを使用して、テーブルのすべてのレコードを表示します。クエリは次のとおりです-
mysql> select *from ReverseBooleanField;
以下は出力です-
+----+---------+ | Id | isValid | +----+---------+ | 1 | 1 | | 2 | 0 | | 3 | 1 | | 4 | 1 | | 5 | 0 | +----+---------+ 5 rows in set (0.00 sec)
MySQLは内部でBOOLEANをTINYINT(1)に変換します。これにより、trueが1、falseが0になります。
ここで、単一のクエリでブールフィールドを逆にしましょう-
mysql> update ReverseBooleanField set isValid = if(isValid,0,1); Query OK, 5 rows affected (0.21 sec) Rows matched − 5 Changed − 5 Warnings − 0
selectステートメントを使用して、ブールフィールドが逆になっていないかどうかを確認します。クエリは次のとおりです-
mysql> select *from ReverseBooleanField;
以下は出力です-
+----+---------+ | Id | isValid | +----+---------+ | 1 | 0 | | 2 | 1 | | 3 | 0 | | 4 | 0 | | 5 | 1 | +----+---------+ 5 rows in set (0.00 sec)
-
1つのMySQLクエリで2つの列を更新します
このためには、SETコマンドを1回だけ使用する必要があります。まずテーブルを作成しましょう- mysql> create table DemoTable1909 ( Id int NOT NULL, FirstName varchar(20), LastName varchar(20) ); Query OK, 0 rows affected (0.00 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> ins
-
単一のクエリでIN()を使用してMySQLテーブルからレコードを削除する
テーブルを作成しましょう- mysql> create table DemoTable1922 ( StudentId int NOT NULL AUTO_INCREMENT PRIMARY KEY, StudentName varchar(20) ); Query OK, 0 rows affected (0.00 sec) 挿入コマンド-を使用して、テーブルにいくつかのレコードを挿入します mysql> insert into DemoTable1922(StudentNa