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

MySQL 查询常用操作(2) —— 条件查询 where

MySQL中常用的查询操作,首先是能直接从表中直接取出数据,接着能对查询结果做一些简单的处理,比如去重等,然后是根据条件查询数据,包括精准查询、模糊查询以及按照数据的某个范围或者指定多个指标进行查询,值得注意的是,MySQL中的一些查询会忽略空值。最后是将查询结果进行排序,主要包括升序和降序以及多个字段的先后排序处理。

第二部分主要介绍where语句——按照条件筛选数据。

一、具体方法

条件查询

select … where查询的基本语法

select * from 表名 where 条件;

条件使用where子句对表中的数据筛选,结果为true的行会出现在结果集中。

注意:

分为between、in、>、like null等

问题类型方法
查找学校是北大的学生信息精准查询where =、where in
查找除复旦大学的用户信息非、比较运算符<>、!=、not in
查找某个年龄段的用户信息某个范围>= 和 <=、between
找到学校为北大、复旦和山大的用户信息同一列多指标查询Where in
查看学校名称中含北京的用户模糊查询like
取出所有年龄值不为空的用户过滤空值<> ‘null’、!= ‘null’、is not null
寻找用户推荐人对空值的处理where 对空值的处理

二、实例

已知有用户信息表user_profile(device_id 设备ID, gender 性别, age 年龄, university 学校, gpa)

iddevice_idgenderageuniversitygpa
12138male21北京大学3.4
23214male复旦大学4.0
36543female20北京大学3.2
42315female23浙江大学3.6
55432male25山东大学3.8
62131male28北京师范大学3.3

题目1:取出所有北京大学的学生的数据,结果返回设备id和学校

【分类】:精准查询

【知识点】:=、in

求解代码
# 使用 =
select 
    device_id,
    university
from user_profile
where university = '北京大学';
# 使用 in
select 
    device_id,
    university
from user_profile
where university in ('北京大学');
结果
device_iduniversity
2138北京大学
6543北京大学

题目2:取出除复旦大学以外的所有用户明细,结果返回设备id和学校

【分类】:、比较运算符

【知识点】:<>、!=、not in

求解代码
# 使用 <>
select 
    device_id,
    university
from user_profile
where university <> '复旦大学';
# 使用 !=
select 
    device_id,
    university
from user_profile
where university != '复旦大学';
# 使用 not in
select 
    device_id,
    university
from user_profile
where university not in('复旦大学');
结果
device_iduniversity
2138北京大学
6543北京大学
2315浙江大学
5432山东大学
2131北京师范大学

题目3: 取出用户年龄在20岁及以上且23岁及以下的设备ID、性别、年龄的数据

【分类】:某个范围

【知识点】: >= 和 <=、between

between: 闭区间,包括左右两边的数。
求解代码
# 使用 \>= 和 <=
select
    device_id,
    gender,
    age
from user_profile
where age >= 20 and age <= 23;

# 使用 between and
select
    device_id,
    gender,
    age
from user_profile
where age between 20 and 23;
结果
device_idgenderage
2138male21
6543female20
2315female23

题目4: 取出学校为北大、复旦和山大的同学的相关数据

【分类】:同一列多指标查询

【知识点】:Where in

求解代码
select
    device_id,
    gender,
    age,
    university,
    gpa
from user_profile
where university in('北京大学','复旦大学','山东大学');
结果
device_idgenderageuniversitygpa
2138male21北京大学3.4
3214male复旦大学4.0
6543female20北京大学3.2
5432male25山东大学

题目5:取出所有大学中带有北京的用户的device_id、age、university的信息

【分类】:模糊查询

【知识点】:like

求解代码
select
    device_id,
    age,
    university
from user_profile
where university like '%北京%';
结果
device_idageuniversity
213821北京大学
654320北京大学
213128北京师范大学

题目6:取出所有年龄值不为空的用户的设备ID,性别,年龄,学校的信息

【分类】:过滤空值

【知识点】:<> ‘null’、!= ‘null’、is not null

求解代码
# 使用 is not null
select 
    device_id,
    gender,
    age,
    university
from user_profile
where age is not null;
# 使用 != 'null'
select 
    device_id,
    gender,
    age,
    university
from user_profile
where age != 'null';
# 使用 <> 'null'
select 
    device_id,
    gender,
    age,
    university
from user_profile
where age <> 'null';
结果
device_idgenderageuniversity
2138male21北京大学
6543female20北京大学
2315female23浙江大学
5432male25山东大学
2131male28北京师范大学

题目7:取出用户信息表中年龄 不是 20 的用户device_id、age、university信息

【分类】:对空值的处理

【知识点】:like

注意:
1. 使用in时,忽略null值,不会查询条件为null的数据;
2. 使用not in时,如果 not in后面的括号中没有null,会查询条件列中符合要求的数据,但会过滤掉条件为null的数据;
3. 使用not in时,如果 not in后面的括号中有null,直接返回false,查询结果为空。
求解代码
# 错误解法
select
	device_id,
    age,
    university
from user_profile
where age <> 20;
# 正确解法
select
	device_id,
    age,
    university
from user_profile
where ifnull(age,1) <> 20;
结果
device_idageuniversity
213821北京大学
3214None复旦大学
231523浙江大学
543225山东大学
213128北京师范大学

创建 user_profile 表的代码

-- ----------------------------
-- Table structure for user_profile
-- ----------------------------
DROP TABLE IF EXISTS `user_profile`;
CREATE TABLE `user_profile`  (
  `id` int(11) NOT NULL,
  `device_id` int(11) NOT NULL,
  `gender` varchar(14) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `age` int(11) NULL DEFAULT NULL,
  `university` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `gpa` float NULL DEFAULT NULL
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of user_profile
-- ----------------------------
INSERT INTO `user_profile` VALUES (1, 2138, 'male', 21, '北京大学', 3.4);
INSERT INTO `user_profile` VALUES (2, 3214, 'male', NULL, '复旦大学', 4);
INSERT INTO `user_profile` VALUES (3, 6543, 'female', 20, '北京大学', 3.2);
INSERT INTO `user_profile` VALUES (4, 2315, 'female', 23, '浙江大学', 3.6);
INSERT INTO `user_profile` VALUES (5, 5432, 'male', 25, '山东大学', 3.8);
INSERT INTO `user_profile` VALUES (6, 2131, 'male', 28, '北京师范大学', 3.3);

SET FOREIGN_KEY_CHECKS = 1;

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

相关文章:

  • 网络安全-web渗透环境搭建-BWAPP(基础篇)
  • 上门按摩系统架构与功能分析
  • Docker中运行Qt应用程序——待继续研究
  • 计算机网络(第8版)第3章--PPP课后习题
  • 智能工厂的设计软件 应用场景的一个例子: 为AI聊天工具添加一个知识系统 之24 重审 前端实现:主页页面
  • PCL 分段线性函数
  • chatGPT的API一次多少钱-怎么用chatGPT解决问题
  • ​如何处理Xcode上传IPA文件后无法在后台架构版本中显示的问题?
  • 2023疫情当头,3个月转行软件测试拿下8k+offer,我心满意足了
  • C 输入 输出
  • 辉煌优配|A股上市银行拟合计派现超5300亿元 14家股息率在5%以上
  • Elasticsearch 8.X 如何基于用户指定 ID 顺序召回数据?
  • android framework-init进程
  • 后缀为whl的文件是什么?如何安装whl文件?学习一下(22)
  • 【荐读】三读上古遗迹之《人月神话》
  • 制剂研发工程师-制剂项目经理-面试问题30个(面试必阅)
  • 1.4 无穷小与无穷大
  • 通讯录(静态版+动态版+文件版)
  • 多线程之最大并行数
  • ChatGPT 与 Midjourney 强强联手,让先秦阿房宫重现辉煌!
  • ChatGPT如何写作-chatGpt自动写文章
  • ECF机制:信号 (Signal)
  • 2023年NOC大赛加码未来编程赛道-初赛-Python(小学高年级组-卷1)
  • Anaconda详细安装使用
  • iosApplePay
  • SpringBoot + MyBatisPlus实现Yaml配置参数AES算法加密