sql简单练习——随笔记

一、is null 判断空值

数据库中的空值<null>

null字符串不可以用is null查询 ='null'

in 加列表可查询多个 国家

sql 复制代码
select name,population 
from world where name in ('sweden','norway','denmark')

这种写法等同于用in加列表的形式,in的多条件逻辑等同于or ,满足其中一个条件即可

IN操作符的作用

IN操作符在SQL中用于匹配括号内指定的任意一个值。当使用IN操作符时,如果字段值与括号内的任何一个值匹配,该行就会被包含在结果集中。IN操作符可以简化多个OR条件的组合查询。
模糊条件查询:

%出现任意字符

_出现一次

1.以C开头且以ia结尾(中间的值均不重要)

2.只要第二个字符为t的国家(选用_占位)

3.被两个o中间隔开

知识点:1.指定几个字符时使用几个通配符_来代替要求的字符数,没有指定字符数时使用通配符% 2.like后的字符和通配符的组合表达式需要用 英文单引号 ''包裹


多条件查询:

SQL 查询语句解析

SQL 查询从 world 表中选择符合特定条件的国家名称 (name) 和面积 (area)。查询条件由多个逻辑运算符组合而成。

查询条件分解

WHERE 子句包含两个主要部分,通过 OR 连接:

  1. 第一部分 (name LIKE '%a%a%a%' AND area > 600000)

    • 查找名称中包含至少三个字母 "a" 的国家
    • 同时面积必须大于 600,000 平方公里
  2. 第二部分 (population > 130000000 AND area > 5000000)

    • 查找人口超过 1.3 亿的国家
    • 同时面积必须超过 5,000,000 平方公里

关键知识点

LIKE 操作符
% 是通配符,表示任意数量的任意字符。'%a%a%a%' 匹配包含至少三个 "a" 的字符串,无论它们出现在什么位置。

逻辑运算符优先级
AND 优先级高于 OR。查询等效于:
(name LIKE '%a%a%a%' AND area > 600000) OR (population > 130000000 AND area > 5000000)

数值比较

使用 > 比较数值大小,注意单位一致性(这里面积和人口的单位应与表定义一致)。

查询结果特征

结果将包括:

  • 所有名称含三个 "a" 且面积大于 60 万平方公里的国家
  • 或人口超 1.3 亿且面积超 500 万平方公里的国家
  • 只返回名称和面积两列

边界值可以用!=来处理

例如:population > 130000000 AND area > 5000000 and area != 50000000

例题:查找诺贝尔奖中在1980年非chemistry和medicine的信息

相关推荐
Evan芙1 小时前
nginx核心配置总结,并实现nginx多虚拟主机
运维·数据库·nginx
Hello.Reader2 小时前
Flink SQL CREATE 语句从建表到 CTAS/RTAS,一次讲清
sql·flink·linq
amao99882 小时前
数据库--dataset design
数据库
山沐与山3 小时前
【数据库】PostgreSQL架构与索引深度剖析
数据库·postgresql·架构
不穿格子的程序员3 小时前
Redis篇6——Redis深度剖析:从单机到集群,Redis高可用进化史
数据库·redis·集群·主从·高可用·哨兵
阿坤带你走近大数据3 小时前
什么是元数据管理?(附具体实施方案供参考)
数据库·金融
俊男无期4 小时前
超效率工作法
java·前端·数据库
2301_823438024 小时前
【无标题】解析《采用非对称自玩实现强健多机器人群集的深度强化学习方法》
数据库·人工智能·算法
中国胖子风清扬4 小时前
SpringAI和 Langchain4j等 AI 框架之间的差异和开发经验
java·数据库·人工智能·spring boot·spring cloud·ai·langchain
Elastic 中国社区官方博客4 小时前
Elasticsearch:你是说,用于混合搜索(hybrid search)
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索