当前位置:主页 > 聚焦 >

认识SQL 高级进阶

时间:2020-12-06 04:41:49

  

 

  sql教程栏目介绍10种高级进阶

  (免费):sql教程

  sql高级
1、TOP子句
TOP 子句用于规定要返回的记录的数目。
 

  SELECT TOP 2 * FROM Persons SELECT TOP 50 PERCENT * FROM Persons

  2、link查找的模式
现在,我们希望从上面的 “Persons” 表中选取居住在以 “N” 开始的城市里的人:
我们可以使用下面的 SELECT 语句:
 

  SELECT * FROM Persons WHERE City LIKE ‘N%’

  提示:”%” 可用于定义通配符(模式中缺少的字母)
通过使用 NOT 关键字,我们可以从 “Persons” 表中选取居住在不包含 “lon” 的城市里的人:
我们可以使用下面的 SELECT 语句:
 

  SELECT * FROM Persons WHERE City NOT LIKE ‘%lon%’

  3、通配符

(1)通过使用 NOT 关键字,我们可以从 “Persons” 表中选取居住在不包含 “lon” 的城市里的人:
我们可以使用下面的 SELECT 语句:
 

  SELECT * FROM Persons WHERE City NOT LIKE ‘%lon%’

  (2)我们希望从上面的 “Persons” 表中选取名字的第一个字符之后是 “eorge” 的人:
我们可以使用下面的 SELECT 语句:
 

  SELECT * FROM Persons WHERE FirstName LIKE ‘_eorge’

  (3)我们希望从上面的 “Persons” 表中选取居住的城市以 “A” 或 “L” 或 “N” 开头的人:
我们可以使用下面的 SELECT 语句:
 

  SELECT * FROM Persons WHERE City LIKE ‘[ALN]%’ 不 SELECT * FROM Persons WHERE City LIKE ‘[!ALN]%’

  4、IN 操作符
IN 操作符允许我们在 WHERE 子句中规定多个值。IN 操作符实例
现在,我们希望从上表中选取姓氏为 Adams 和 Carter 的人:
我们可以使用下面的 SELECT 语句:
 

  SELECT * FROM Persons WHERE LastName IN (‘Adams’,’Carter’)

  5、BETWEEN 操作符
操作符 BETWEEN … AND 会选取介于两个值之间的数据范围。这些值可以是数值、文本或者日期
如需以字母顺序显示介于 “Adams”(包括)和 “Carter”(不包括)之间的人,请使用下面的 SQL:

  SELECT * FROM Persons WHERE LastName BETWEEN ‘Adams’ AND ‘Carter’

  补集为No BETWEEN
 

  6、通过使用 SQL,可以为列名称和表名称指定别名(Alias)
假设我们有两个表分别是:”Persons” 和 “Product_Orders”。我们分别为它们指定别名 “p” 和 “po”。
现在,我们希望列出 “John Adams” 的所有定单。
我们可以使用下面的 SELECT 语句:
 

  也可以为列使用别名
 

  SELECT LastName AS Family, FirstName AS Name FROM Persons

  7、join 和 Key
有时为了得到完整的结果,我们需要从两个或更多的表中获取结果。我们就需要执行 join。
数据库中的表可通过键将彼此联系起来。主键(Primary Key)是一个列,在这个列中的每一行的值都是唯一的。


引用两个表
我们可以通过引用两个表的方式,从两个表中获取数据:
谁订购了产品,并且他们订购了什么产品?
 

  SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo FROM Persons, Orders WHERE Persons.Id_P = Orders.Id_P

  下面的语句和上面的语句具有同样的效果
SQL JOIN - 使用 Join
除了上面的方法,我们也可以使用关键词 JOIN 来从两个表中获取数据。
如果我们希望列出所有人的定购,可以使用下面的 SELECT 语句:
 

  SELECT Persons.LastName, Persons.FirstName, Orders.OrderNo FROM Persons INNER JOIN Orders ON Persons.Id_P = Orders.Id_P ORDER BY Persons.LastName

  INNER JOIN 存在至少一个匹配时返回行

  注意:

  JOIN: 如果表中有至少一个匹配,则返回行

  LEFT JOIN: 即使右表中没有匹配,也从左表返回所有的行

  RIGHT JOIN: 即使左表中没有匹配,也从右表返回所有的行

  FULL JOIN: 只要其中一个表中存在匹配,就返回行
 

  8、SQL UNION 操作符
UNION 操作符用于合并两个或多个 SELECT 语句的结果集。
请注意,UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条 SELECT 语句中的列的顺序必须相同。
列出所有在中国和美国的不同的雇员名:
 

  SELECT E_Name FROM Employees_China UNION SELECT E_Name FROM Employees_USA

  union和union all的区别就是union all会把所有的结果都输出来,union会把相同的给去掉
 

  9、CREATE DATABASE database_name
用于创建数据库
 

  CREATE TABLE Persons ( Id_P int, LastName varchar(255), FirstName varchar(255), Address varchar(255), City varchar(255) )

  
 

  10、sql约束
(1) 下面的 SQL 语句强制 “Id_P” 列和 “LastName” 列不接受 NULL 值:

  CREATE TABLE Persons ( Id_P int NOT NULL, LastName varchar(255) NOT NULL, FirstName varchar(255), Address varchar(255), City varchar(255) )

  (2)SQL UNIQUE 约束

  UNIQUE 约束唯一标识数据库表中的每条记录。

  UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证

  PRIMARY KEY 拥有自动定义的 UNIQUE 约束。

  请注意,每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束。
(3)SQL PRIMARY KEY 约束
PRIMARY KEY 约束唯一标识数据库表中的每条记录。

  主键必须包含唯一的值。

  主键列不能包含 NULL 值。
每个表都应该有一个主键,并且每个表只能有一个主键。

  想了解更多编程学习,敬请关注php培训栏目!
 

热点推荐
1 bitmine质押162,088枚ETH,当前质押规模达4

消息,据onchain lens监测,bitmine于6小时前质押162,088枚ETH,价值约3.6567亿美元其当前质押规模达...

2 DeepSeek多模态技术报告:教模型「用手指

消息,DeepSeek发布了多模态推理技术报告「thinking with visual primitives」,提出了一种新推理范式...

3 未知钱包解除质押1亿枚XRP,价值约1367.

消息,据链上监测平台Whale Alert数据,某未知钱包刚刚解除质押100,000,000枚XRP,按实时价格计算...

4 特朗普:不在乎鲍威尔留任理事仍待验证

消息,美国总统特朗普表示,即便鲍威尔在美联储主席任期结束后仍然留任理事一职,他也不...

5 霍斯金森批评Ripple CEO:清晰法案或倾斜市

消息,Cardano创始人查尔斯霍斯金森批评了Ripple CEO布拉德加林豪斯,警告称清晰法案可能会偏向...

6 美元因伊朗停火协议退潮,面临最大月度

消息,美元指数因美国与伊朗停火协议的希望减弱而面临自2025年6月以来的最大月度跌幅。数据...

7 阿联酋检察总长将13名被告移交国家安全

消息,阿联酋检察总长将13名被告及6家公司移交国家安全法庭,原因是企图将军事物资转运至...

8 巴西批准发行2.1亿巴西雷亚尔比特币担保

消息,巴西批准发行最高达2.1亿巴西雷亚尔的比特币担保债券,以资助进一步的比特币积累。...

9 KelpDAO向DeFi United恢复基金贡献2000 ETH

消息,KelpDAO宣布已向DeFi United恢复基金提供2000 ETH财政资金,旨在恢复RSETH的挂钩支持。此次资...

10 多位美国参议员就卢特尼克贷款事宜致信

消息,多位美国参议员就卢特尼克贷款事宜致信Tether公司首席执行官。此外,参议员们还就向...

成都来彰科技 蜀ICP备2025134723号-1

资讯来源互联网,如有版权问题请联系管理员删除。