SQL必知会(二)-SQL查询篇(1)-检索数据

第2课、检索数据

SELECT:查询
从一个或多个表中检索信息。

|-------------|
| 1)检索单个列 |

需求:从 Products 表中查询所有行的产品名称。

sql 复制代码
SElECT prod_name
FROM Products;

输出结果:

|-------------|
| 2)检索多个列 |

需求:从 Products 表中查询所有行的产品ID、名称和价格。

sql 复制代码
SELECT prod_id,prod_name,prod_price
FROM Products;

输出结果:

|-------------|
| 3)检索所有列 |

需求:从 Products 表中查询所有行的所有列。

sql 复制代码
SELECT * FROM Products;

输出结果:

|--------------|
| 4)检索不同的值 |

需求:检索 Products 表中所有产品供应商的 ID。

sql 复制代码
SELECT vend_id
From Products;

输出结果:

DISTINCT:过滤重复的记录
DISTINCT:过滤掉多余的重复记录只保留一条

需求:检索 Products 表中所有产品供应商的 ID,并不重复出现相同的值。

sql 复制代码
SELECT DISTINCT vend_id
From Products;

输出结果:

如果使用如下命令,则 DISTINCT 对 vend_id 和 prod_price 组合有两种不同的结果,并同时一起输出:

sql 复制代码
SELECT DISTINCT vend_id, prod_price
From Products;

/*
(个人思考)
如果把语法中的 vend_id 和 prod_price 的位置互换一下:

SELECT DISTINCT prod_price,vend_id
From Products;

1.从输出结果来看,就会发现:
- DISTINCT 后的第一列会默认升序排序
- 当 某个列检索得出不同值的个数是所有列中最多的,以该列输出不重复值为准。
- 而其他列值依旧存在重复值。

2.尝试执行其他代码,自己可以研究一下结果:
SELECT DISTINCT vend_id,prod_name, prod_price
From Products;

SELECT DISTINCT vend_id, prod_price
From Products 
ORDER BY prod_price ASC;
(DISTINCT vend_id 列排序失效,按 prod_price 升序排序)
*/

输出结果:

|------------|
| 5)限制结果 |

TOP:最多返回的行数
限制最多返回多少行。

需求:只检索前5行数据。

  • SQL 语句:
sql 复制代码
SELECT TOP 5 prod_name
FROM Products;
  • 如果使用 DB2:
sql 复制代码
SELECT prod_name
FROM Products
FETCH FIRST 5 ROWS ONLY;
  • 如果使用 Oracle:
sql 复制代码
SELECT prod_name
FROM Products
Where ROWNUM <=5; 
  • 如果使用 MySQL、MariaDB、PostgreSQL 或者 SQLite:
sql 复制代码
SELECT prod_name
FROM Products
LIMIT 5;
SQL 复制代码
SELECT prod_name
FROM Products
LIMIT 5 OFFSET 5;
-- 从第5行起的5行数据

输出结果:

总结

SELECT:查询

复制代码
SELECT 列
FROM 表

DISTINCT:过滤掉多余的重复记录只保留一条

复制代码
SELECT DISTINCT 列
From 表;

TOP:限制最多返回多少行

复制代码
SELECT TOP 行数 列
FROM 表;
相关推荐
春风霓裳4 小时前
sql-窗口函数
大数据·数据库·sql
言之。4 小时前
【数据库】TiDB 技术选型与架构分析报告
数据库·架构·tidb
人工智能训练4 小时前
如何在 Ubuntu 22.04 中安装 Docker 引擎和 Linux 版 Docker Desktop 桌面软件
linux·运维·服务器·数据库·ubuntu·docker·ai编程
胖头鱼的鱼缸(尹海文)5 小时前
数据库管理-第386期 使用OCP部署OceanBase 4.4.1社区版集群(20251107)
数据库·oceanbase
Craaaayon5 小时前
如何选择两种缓存更新策略(写缓存+异步写库;写数据库+异步更新缓存)
java·数据库·redis·后端·缓存·mybatis
一 乐5 小时前
点餐|智能点餐系统|基于java+ Springboot的动端的点餐系统小程序(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·小程序·论文
WarriorTan5 小时前
理解PostgreSQL中的数据块
数据库·postgresql
学好statistics和DS5 小时前
三个好思路:SQL并行化处理、混淆矩阵和特征交叉
数据库·sql·矩阵
唐僧洗头爱飘柔95276 小时前
【GORM(3)】Go的跨时代ORM框架!—— 数据库连接、配置参数;本文从0开始教会如何配置GORM的数据库
开发语言·数据库·后端·golang·gorm·orm框架·dsn
谅望者6 小时前
在 macOS 上使用 Homebrew 安装 MySQL 8.0 完整指南
数据库·sql·mysql