一、题目
患者信息表: Patients
+--------------+---------+
| Column Name | Type |
+--------------+---------+
| patient_id | int |
| patient_name | varchar |
| conditions | varchar |
+--------------+---------+
patient_id (患者 ID)是该表的主键。
'conditions' (疾病)包含 0 个或以上的疾病代码,以空格分隔。
这个表包含医院中患者的信息。
写一条 SQL 语句,查询患有 I 类糖尿病的患者 ID (patient_id)、患者姓名(patient_name)以及其患有的所有疾病代码(conditions)。I 类糖尿病的代码总是包含前缀 DIAB1 。
按 任意顺序 返回结果表。
查询结果格式如下示例所示。
示例 1:
输入:
Patients表:
+------------+--------------+--------------+
| patient_id | patient_name | conditions |
+------------+--------------+--------------+
| 1 | Daniel | YFEV COUGH |
| 2 | Alice | |
| 3 | Bob | DIAB100 MYOP |
| 4 | George | ACNE DIAB100 |
| 5 | Alain | DIAB201 |
+------------+--------------+--------------+
输出:
+------------+--------------+--------------+
| patient_id | patient_name | conditions |
+------------+--------------+--------------+
| 3 | Bob | DIAB100 MYOP |
| 4 | George | ACNE DIAB100 |
+------------+--------------+--------------+
解释:Bob 和 George 都患有代码以 DIAB1 开头的疾病。
二、解决
1、or
思路: 略。 代码:
select
patient_id
, patient_name
, conditions
from patients
where conditions like "DIAB1%" or conditions like "% DIAB1%" ;
2、正则表达式
思路: 略。 代码:
SELECT * FROM PATIENTS
WHERE CONDITIONS REGEXP '^DIAB1|\\sDIAB1';
where conditions regexp '\\bDIAB1.*\\b' ;
where conditions regexp '^DIAB1.*|[[:space:]]DIAB1.*' ;
WHERE conditions REGEXP '(^DIAB1| DIAB1)' ;
三、参考
1、SQL: 学习正则表达式匹配 2、MySQL 正则表达式 3、采用正则表达式 超过91.20% 4、优雅的正则,只需一行WHERE子句
|