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

別のフィールドに文字列が含まれている場合、MySQLの選択でtrueまたはfalseを返しますか?


別のフィールドに文字列が含まれている場合にTRUEまたはFALSEを返すには、IF()を使用します。まずテーブルを作成しましょう

mysql> create table DemoTable
(
   FirstName varchar(100),
   LastName varchar(100)
);
Query OK, 0 rows affected (1.28 sec)

挿入コマンド-

を使用して、テーブルにいくつかのレコードを挿入します
mysql> insert into DemoTable values('Chris','Brown');
Query OK, 1 row affected (0.17 sec)
mysql> insert into DemoTable values('David','Miller');
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable values('Adam','Smith');
Query OK, 1 row affected (0.11 sec)

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

mysql> select *from DemoTable;

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

+-----------+----------+
| FirstName | LastName |
+-----------+----------+
| Chris     | Brown    |
| David     | Miller   |
| Adam      | Smith    |
+-----------+----------+
3 rows in set (0.00 sec)

以下は、別のフィールドに文字列が含まれている場合にMySQLselectでtrueまたはfalseを返すクエリです。ここでは、文字列「Miller」をチェックしています-

Mysql> select if(LastName=’Miller’,’Yes','No') AS LastName,FirstName from DemoTable;

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

+----------+-----------+
| LastName | FirstName |
+----------+-----------+
| No       | Chris     |
| Yes      | David     |
| No       | Adam      |   
+----------+-----------+
3 rows in set (0.00 sec)

  1. MySQLでTRUEFALSEレコードを01として表示する

    0と1の値を表示するには、列をBOOLEANに設定します。テーブルを作成しましょう- mysql> create table DemoTable2035    -> (    -> Id int NOT NULL AUTO_INCREMENT,    -> Name varchar(20),    -> isMarried boolean,    -> PRIMARY KEY(Id)    -> ); Query OK, 0 rows

  2. 文字列に10進文字のみが含まれているかどうかを確認するにはどうすればよいですか?

    Stringクラスにはisdigit()というメソッドがあり、文字列内のすべての文字が数字であり、少なくとも1つの文字がある場合はtrueを返し、それ以外の場合はfalseを返します。次のように呼び出すことができます: >>> "12345".isdigit() True >>> "12345a".isdigit() False しかし、これは浮動小数点数では失敗します。これらの番号には、次の方法を使用できます。 def isfloat(value):   try:     float(