当前位置: 首页 > article >正文

力扣-患某种疾病的患者

大家好,我是空空star,本篇带大家了解一道简单的力扣sql练习题。

文章目录

  • 前言
  • 一、题目:1527. 患某种疾病的患者
  • 二、解题
    • 1.正确示范①
      • 提交SQL
      • 运行结果
    • 2.正确示范②
      • 提交SQL
      • 运行结果
    • 3.正确示范③
      • 提交SQL
      • 运行结果
    • 4.正确示范④
      • 提交SQL
      • 运行结果
    • 5.其他
  • 总结


前言


一、题目:1527. 患某种疾病的患者

患者信息表: 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 。
按 任意顺序 返回结果表。
查询结果格式如下示例所示。

输入:
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.正确示范①

提交SQL

select patient_id,patient_name,conditions
from Patients 
where conditions like 'DIAB1%'
or conditions like '% DIAB1%';

运行结果

2.正确示范②

提交SQL

select patient_id,patient_name,conditions
from Patients 
where conditions  REGEXP '^DIAB1|\\sDIAB1';

运行结果

3.正确示范③

提交SQL

select patient_id,patient_name,conditions
from Patients 
where conditions rlike '^DIAB1|\\sDIAB1';

运行结果

4.正确示范④

提交SQL

select patient_id,patient_name,conditions
from Patients 
where conditions like 'DIAB1%'
union
select patient_id,patient_name,conditions
from Patients 
where conditions like '% DIAB1%';

运行结果

5.其他


总结

正确示范①思路:
like + or +like
正确示范②思路:
REGEXP
正确示范③思路:
rlike
正确示范④思路:
like + union + like


http://www.kler.cn/a/3276.html

相关文章:

  • windows安装ES
  • JAVA:利用 Content Negotiation 实现多样式响应格式的技术指南
  • 入门 Canvas:Web 绘图的强大工具
  • K8S中的数据存储之基本存储
  • 【Uniapp-Vue3】动态设置页面导航条的样式
  • YOLOv8改进,YOLOv8检测头融合DynamicHead,并添加小目标检测层(四头检测),适合目标检测、分割等,全网独发
  • CAN通信----电路图
  • leetcode 回文链表
  • 【多线程】常见的锁策略
  • 【CE进阶】lua脚本使用
  • 网站性能优化篇
  • asio(八)、异步TCP服务器
  • Sass(Scss)学习
  • java 多线程,线程池
  • Python用湖南天气详情数据(可惜没雨),进行简单的可视化分析
  • Mybatis(四):自定义映射resultMap
  • 入侵检测——如何实现反弹shell检测?
  • 会声会影2023专业旗舰版新功能介绍
  • Linux - 进程概念
  • 机器学习----线性回归
  • 第十四届蓝桥杯三月真题刷题训练——第 22 天
  • ChatGPT 有哪些神奇的使用方式?
  • 【Vue2从入门到精通】详解Vue.js的15种常用指令及其使用场景
  • 设计循环队列(图示超详解哦)
  • 计网之HTTP协议和Fiddler的使用
  • C++之模拟实现string