数据库基础之,MySQL条件查询是怎么回事?
wptr33 2024-12-28 15:59 30 浏览
前言
从今天开始,本系列内容就带各位小伙伴学习数据库技术。数据库技术是Java开发中必不可少的一部分知识内容。也是非常重要的技术。本系列教程由浅入深, 全面讲解数据库体系。 非常适合零基础的小伙伴来学习。
全文大约【1263】字,不说废话,只讲可以让你学到技术、明白原理的纯干货!本文带有丰富案例及配图,让你更好的理解和运用文中的技术概念,并可以给你带来具有足够启迪的思考......
一. 数据库条件查询
语法:SELECT 列名 FROM 表名 WHERE 条件
关键字 | 描述 |
WHERE 条件 | 在查询结果中,筛选符合条件的查询结果,条件为布尔表达式 |
1、等值判断(=)
#查询年龄等于12的学生
SELECT SId, Sname, Sage, Ssex from student where Sage=12;
注意:与 java 不同(==),mysql 中等值判断使用 =
2、逻辑判断(and、or、not)
#查询年龄等于12并且性别是男的学生
SELECT SId, Sname, Sage, Ssex from student where Sage=12 and Ssex='男';
3、不等值判断(> 、< 、>= 、<= 、!= 、<>)
#查询年龄大于等于12并且小于等于50的学生
SELECT SId, Sname, Sage, Ssex from student where Sage >= 12 and sage <= 50;
4、区间判断(between and)
#查询年龄在12~50之间的学生信息
SELECT SId, Sname, Sage, Ssex from student where Sage BETWEEN 12 and 50;
5、NULL 值判断(IS NULL、IS NOT NULL)
语法 :
列名 IS NULL
列名 IS NOT NULL
#查询年龄为null的学生信息
SELECT SId, Sname, Sage, Ssex from student where Sage is NULL;
6、枚举查询( IN (值 1,值 2,值 3 ) )
#查询年龄为12, 33, 44的学生信息
SELECT SId, Sname, Sage, Ssex from student where Sage in(12,33,44);
注:in的查询效率较低,可通过多条件拼接。
7、模糊查询
语法 :
LIKE _ (单个任意字符)列名 LIKE '张_'
LIKE %(任意长度的任意字符)列名 LIKE '张%'
注意:模糊查询只能和 LIKE 关键字结合使用。
#查询姓李的学生信息
SELECT SId, Sname, Sage, Ssex from student where Sname like '李%';
8.分支结构查询
语法 :
SELECT 字段名
CASE
WHEN 条件1 THEN 结果1
WHEN 条件2 THEN 结果2
WHEN 条件3 THEN 结果3
ELSE 结果
END as 别名
FROM 表名
注意:通过使用CASE END进行条件判断,每条数据对应生成一个值。
经验:类似 Java 中的switch。
#查询学生信息, 年龄大于等于10小于等于20显示A, 大于等于21小于等于40显示B, 其他显示C
SELECT SId, Sname, Ssex,
case
when Sage >= 10 and Sage <= 20 then 'A'
when Sage >= 21 and Sage <= 40 then 'B'
else 'C'
end as 'level'
from student ;
二. 结语
最后在这里对本文核心要点进行总结:
1. 条件查询是我们日常查询中最为基本也是最为重要的查询。
2. 熟练使用等值判断、逻辑判断、不等值判断、区间判断、null值判断、枚举查询、模糊查询。
3. 分支结构条件查询语法比较复杂,在某些特定情况可以起到意想不到的效果,需要熟练掌握。
更多精彩内容,关注@千锋教育
相关推荐
- Java常用工具类技术文档(java常用util工具类)
-
一、概述Java工具类(UtilityClasses)是封装了通用功能的静态方法集合,能够简化代码、提高开发效率。本文整理Java原生及常用第三方库(如ApacheCommons、GoogleG...
- 建议收藏!深入理解Java虚拟机:JVM垃圾回收算法+垃圾收集器
-
02JVM垃圾回收算法2.1什么是垃圾回收?...
- Java 开发者线上问题排查常用的 15 个 Linux 命令
-
作为Java开发者,线上环境的问题排查是日常工作的重要组成部分。熟练掌握Linux命令能大幅提升排查效率,快速定位进程异常、日志错误、性能瓶颈等核心问题。本文结合Java应用特点,整理1...
- Java-Maven详解(maven for java)
-
一、什么是Maven?ApacheMaven是一个软件...
- java 文件操作(I/O流)(java文件流写入文件)
-
一、文件操作技术演进二、核心类对比分析...
- 如何使用Java API操作HDFS系统?(java编程操作hdfs能完成的功能有)
-
1.搭建项目环境打开Eclipse选择FileàNewàMavenProject创建Maven工程,选择“Createasimpleproject”选项,点击【Next】按钮,会进入“New...
- 那些被"删除"却仍占用空间的文件
-
在服务器运维过程中,磁盘空间不足是一个常见问题。而有时候,即使清理了大量文件,系统仍然报告磁盘几乎已满,这种情况尤为令人困惑。本文将通过一个实际案例,分享如何排查和解决Linux服务器上的"幽...
- SpringBoot的Web应用开发——Web缓存利器Redis的应用!
-
Web缓存利器Redis的应用Redis是目前使用非常广泛的开源的内存数据库,是一个高性能的keyvalue数据库,它支持多种数据结构,常用做缓存、消息代理和配置中心。本节将简单介绍Redis的使...
- Redis 常用命令大全(redis常用命令及详解)
-
Redis常用命令全解析在当今的数据处理与存储领域,Redis凭借其高性能、丰富的数据结构等特性,成为了众多开发者和企业的首选内存数据库。下面将为大家详细介绍Redis的常用命令。键(Key)...
- Redis+Lua脚本防超卖是万能解?这3个致命漏洞你可能没发现!
-
在高并发秒杀场景中,Redis+Lua脚本常被视为防止超卖的“银弹”。然而,许多开发者因对其底层逻辑理解不足,踩中了致命漏洞却不自知。本文通过真实案例剖析三个隐藏极深的问题,并提供完整解决方案,助你避...
- 10w qps缓存数据库——Redis(缓存技术 redis)
-
一、Redis数据库介绍:Redis:非关系型缓存数据库...
- Redis安装及核心数据结构(redis一般安装在哪)
-
Redis安装官方下载地址:http://redis.io/downloadhttp://download.redis.io/releases/...
- Python Redis数据库新玩法:从零到高手掌握操作技巧
-
介绍Redis(RemoteDictionaryServer)是一种高性能的开源内存数据库,它支持多种数据结构,如字符串、哈希、列表、集合、有序集合等,并提供了丰富的操作命令。Redis具有快速、...
- redis知识总结(基础篇,可复习,可学习)
-
最近redis差不多看完了,前面学的也忘了好多,所以正好写篇博客复习复习。此篇介绍的是redis的基础篇,希望这篇能帮到各位大佬。...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
面试官:git pull是哪两个指令的组合?
-
git 执行pull错误如何撤销 git pull fail
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
-
- Java常用工具类技术文档(java常用util工具类)
- 建议收藏!深入理解Java虚拟机:JVM垃圾回收算法+垃圾收集器
- Java 开发者线上问题排查常用的 15 个 Linux 命令
- Java-Maven详解(maven for java)
- java 文件操作(I/O流)(java文件流写入文件)
- 如何使用Java API操作HDFS系统?(java编程操作hdfs能完成的功能有)
- 那些被"删除"却仍占用空间的文件
- SpringBoot的Web应用开发——Web缓存利器Redis的应用!
- 如何使用C#中的Lambda表达式操作Redis Hash结构,简化缓存中对象属性的读写操作
- Redis 常用命令大全(redis常用命令及详解)
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)