SQL必知必会(第四版) 第二课 检索数据-读书笔记

2.1 SELECT语句

  SELECT语句的用途是从一个或多个表中检索信息。

关键字(keyword):
  作为SQL组成部分的保留字。关键字不能作为表或列的名字。

2.2 检索单个列

例如:输入

SELECT prod_name FROM Products; 

  上述语句利用SELECT语句从Products表中检索一个名为prod_name的列,FROM关键字指出从哪个表中检索数据。

输出:
在这里插入图片描述

提示:
  1.多条SQL语句必须以分号分隔;
  2.SQL语句不区分大小写;
  3.SQL语句可以写成长长的一行,也可以分写在多行;

2.3 检索多个列

  想要从一个表中检索多个列,仍然使用相同的SELECT语句,唯一的不同是必须在SELECT关键字后给出多个列名,列名之间必须以逗号分隔。

提示:
  选择多个列时必须在列名之间加上逗号,但最后一个列名不加,否则将出现错误;

例如:输入

SELECT  prod_id, prod_name, prod_price FROM Products; 

输出:
在这里插入图片描述

2.4 检索所有列

  除了指定所需的列外,SELECT语句还可以使用通配符(*)检索所有的列而不必逐个列出它们。

提示:
  1.除非你确实需要表中的每一列,否则最好别使用通配符(*),检索不需要的列通常会降低检索和应用程序的性能;
  2.使用通配符(*)时,能检索出名字未知的列;

例如:输入

SELECT * FROM Products; 

输出:
在这里插入图片描述

2.5 检索不同的值

  SELECT语句将返回所有匹配的行,但有时你不希望每个值每次都出现。

例如:输入

SELECT vend_id FROM Products; 

输出:
在这里插入图片描述
SELECT所返回的行中存在相同的值,那么如何只检索出不同的值呢?
解决办法就是使用DISTINCT关键字,它指示数据库只返回不同的值。

例如:输入

SELECT DISTINCT vend_id FROM Products; 

输出:
在这里插入图片描述

提示:
  DISTINCT关键字作用于所有的列,不仅仅是跟在其后的那一列;

2.6 限制结果

  SELECT语句返回指定表中所有匹配的行,但如果你只想返回第一行或一定数量的行时该怎么办呢?
遗憾的是,各种数据库中的这一SQL实现并不相同。

1.在SQL Server和Access中使用SELECT时,可以使用TOP关键字来限制最多返回多少行

例如:

SELECT TOP 5 prod_name FROM Products; 

2.如果你使用的是DB2时

例如:

SELECT prod_name FROM Products FETCH FIRST 5 ROWS ONLY; 

3.如果你使用的是Oracle,需要基于ROWNUM(行计数器)来计算行

例如:

SELECT prod_name FROM Products WHERE ROWNUM <=5; 

4.如果你使用 MySQL、MariaDB、PostgreSQL或者 SQLite,需要使用 LIMIT 子句

例如:

SELECT prod_name FROM Products LIMIT 5; 

还可以指定从哪儿开始以及检索的行数

例如:

SELECT prod_name FROM Products LIMIT 5 OFFSET 5; 

第一个数字是指从哪儿开始,第二个数字是检索的行数

提示:
  1.第一个被检索的行是第0行,因此LIMIT 1 OFFSET 1 会检索第2行而不是第1行
  2.MYSQL和MariaDB支持简化版的LIMIT,即LIMIT 3 OFFSET 4 = LIMIT 4,3。逗号之前的值对应OFFSET,逗号之后的值对应LIMIT

2.7 使用注释

  SQL语句是由DBMS处理的指令,但如果你希望包括不进行处理和执行的文本时,就可以使用注释。

很多DBMS都支持各种形式的注释语法。
1.行内注释:

SELECT prod_name    -- 这是一条注释  
FROM Products; 

2.另一种形式的行内注释:

# 这是一条注释 
SELECT prod_name  FROM Products; 

3.多行注释:

/* SELECT prod_name, vend_id  
FROM Products; */  
SELECT prod_name  FROM Products;

小结

  这一课学习了如何使用 SQL的 SELECT 语句来检索单个表列、多个表列 以及所有表列。同时也学习了如何返回不同的值,如何注释代码。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值