数据库
首页 > 数据库> > SQL 语法速成手册

SQL 语法速成手册

作者:互联网

本文针对关系型数据库的一般语法。限于篇幅,本文侧重说明用法,不会展开讲解特性、原理。篇幅较长,但内容基本涵盖了SQL语法的大部分内容。

一、基本概念

数据库术语

SQL 语法

SQL(Structured Query Language),标准 SQL 由 ANSI 标准委员会管理,从而称为 ANSI SQL。各个 DBMS 都有自己的实现,如 PL/SQL、Transact-SQL 等。

SQL 语法结构

图片

SQL 语法结构包括:

SQL 语法要点

例如:SELECTselectSelect 是相同的。

-- 一行 SQL 语句
UPDATE user SET username='robot', password='robot' WHERE username = 'root';

-- 多行 SQL 语句
UPDATE user
SET username='robot', password='robot'
WHERE username = 'root';
## 注释1
-- 注释2
/* 注释3 */

SQL 分类

数据定义语言(DDL)

数据定义语言(Data Definition Language,DDL)是 SQL 语言集中负责数据结构定义与数据库对象定义的语言。

DDL 的主要功能是定义数据库对象

DDL 的核心指令是 CREATEALTERDROP

数据操纵语言(DML)

数据操纵语言(Data Manipulation Language, DML)是用于数据库操作,对数据库其中的对象和数据运行访问工作的编程语句。

DML 的主要功能是 访问数据,因此其语法都是以读写数据库为主。

DML 的核心指令是 INSERTUPDATEDELETESELECT。这四个指令合称 CRUD(Create, Read, Update, Delete),即增删改查。

事务控制语言(TCL)

事务控制语言 (Transaction Control Language, TCL) 用于管理数据库中的事务。这些用于管理由 DML 语句所做的更改。它还允许将语句分组为逻辑事务。

TCL 的核心指令是 COMMITROLLBACK

数据控制语言(DCL)

数据控制语言 (Data Control Language, DCL) 是一种可对数据访问权进行控制的指令,它可以控制特定用户账户对数据表、查看表、预存程序、用户自定义函数等数据库对象的控制权。

DCL 的核心指令是 GRANTREVOKE

DCL 以控制用户的访问权限为主,因此其指令作法并不复杂,可利用 DCL 控制的权限有:CONNECTSELECTINSERTUPDATEDELETEEXECUTEUSAGEREFERENCES

根据不同的 DBMS 以及不同的安全性实体,其支持的权限控制也有所不同。

(以下为 DML 语句用法)

二、增删改查

增删改查,又称为 CRUD,数据库基本操作中的基本操作。

插入数据

  • INSERT INTO 语句用于向表中插入新记录。

插入完整的行

INSERT INTO user
VALUES (10, 'root', 'root', 'xxxx@163.com');

插入行的一部分

INSERT INTO user(username, password, email)
VALUES ('admin', 'admin', 'xxxx@163.com');

插入查询出来的数据

INSERT INTO user(username)
SELECT name
FROM account;

更新数据

  • UPDATE 语句用于更新表中的记录。
UPDATE user
SET username='robot', password='robot'
WHERE username = 'root';

删除数据

  • DELETE 语句用于删除表中的记录。
  • TRUNCATE TABLE 可以清空表,也就是删除所有行。

删除表中的指定数据

DELETE FROM user
WHERE username = 'robot';

清空表中的数据

TRUNCATE TABLE user;

查询数据

  • SELECT 语句用于从数据库中查询数据。

  • DISTINCT 用于返回唯一不同的值。它作用于所有列,也就是说所有列的值都相同才算相同。

  • LIMIT 限制返回的行数。可以有两个参数,第一个参数为起始行,从 0 开始;第二个参数为返回的总行数。

    • ASC :升序(默认)
    • DESC :降序

查询单列

SELECT prod_nameFROM products;

查询多列

SELECT prod_id, prod_name, prod_priceFROM products;

查询所有列

ELECT *FROM products;

查询不同的值

SELECT DISTINCTvend_id FROM products;

限制查询结果

-- 返回前 5 行SELECT * FROM mytable LIMIT 5;SELECT * FROM mytable LIMIT 0, 5;-- 返回第 3 ~ 5 行SELECT * FROM mytable LIMIT 2, 3;

三、子查询

子查询是嵌套在较大查询中的 SQL 查询。子查询也称为内部查询内部选择,而包含子查询的语句也称为外部查询外部选择

子查询的子查询

SELECT cust_name, cust_contactFROM customersWHERE cust_id IN (SELECT cust_id                  FROM orders                  WHERE order_num IN (SELECT order_num                                      FROM orderitems                                      WHERE prod_id = 'RGAN01'));

WHERE

运算符描述
=等于
<>不等于。注释:在 SQL 的一些版本中,该操作符可被写成 !=
>大于
<小于
>=大于等于
<=小于等于
BETWEEN在某个范围内
LIKE搜索某种模式
IN指定针对某个列的多个可能值

SELECT 语句中的 WHERE 子句

SELECT * FROM CustomersWHERE cust_name = 'Kids Place';

UPDATE 语句中的 WHERE 子句

UPDATE CustomersSET cust_name = 'Jack Jones'WHERE cust_name = 'Kids Place';

DELETE 语句中的 WHERE 子句

DELETE FROM CustomersWHERE cust_name = 'Kids Place';

IN 和 BETWEEN

IN 示例

SELECT *FROM productsWHERE vend_id IN ('DLL01', 'BRS01');

BETWEEN 示例

SELECT *FROM productsWHERE prod_price BETWEEN 3 AND 5;

AND、OR、NOT

AND 示例

SELECT prod_id, prod_name, prod_priceFROM productsWHERE vend_id = 'DLL01' AND prod_price <= 4;

OR 示例

SELECT prod_id, prod_name, prod_priceFROM productsWHERE vend_id = 'DLL01' OR vend_id = 'BRS01';

NOT 示例

SELECT *FROM productsWHERE prod_price NOT BETWEEN 3 AND 5;

LIKE

% 示例

SELECT prod_id, prod_name, prod_priceFROM productsWHERE prod_name LIKE '%bean bag%';

_ 示例

SELECT prod_id, prod_name, prod_priceFROM productsWHERE prod_name LIKE '__ inch teddy bear';

四、连接和组合

连接(JOIN)

  • 如果一个 JOIN 至少有一个公共字段并且它们之间存在关系,则该 JOIN 可以在两个或多个表上工作。

  • 连接用于连接多个表,使用 JOIN 关键字,并且条件语句使用 ON 而不是 WHERE

  • JOIN 保持基表(结构和数据)不变。

  • JOIN 有两种连接类型:内连接和外连接。

  • 内连接又称等值连接,使用 INNER JOIN 关键字。在没有条件语句的情况下返回笛卡尔积。

    • 自连接可以看成内连接的一种,只是连接的表是自身而已。
  • 自然连接是把同名列通过 = 测试连接起来的,同名列可以有多个。

  • 内连接 vs 自然连接

    • 内连接提供连接的列,而自然连接自动连接所有同名列。
  • 外连接返回一个表中的所有行,并且仅返回来自次表中满足连接条件的那些行,即两个表中的列是相等的。外连接分为左外连接、右外连接、全外连接(Mysql 不支持)。

    • 左外连接就是保留左表没有关联的行。
    • 右外连接就是保留右表没有关联的行。
  • 连接 vs 子查询

    • 连接可以替换子查询,并且比子查询的效率一般会更快。

图片

内连接(INNER JOIN)

SELECT vend_name, prod_name, prod_priceFROM vendors INNER JOIN productsON vendors.vend_id = products.vend_id;

自连接

SELECT c1.cust_id, c1.cust_name, c1.cust_contactFROM customers c1, customers c2WHERE c1.cust_name = c2.cust_nameAND c2.cust_contact = 'Jim Jones';

自然连接(NATURAL JOIN)

SELECT *FROM ProductsNATURAL JOIN Customers;

左连接(LEFT JOIN)

SELECT customers.cust_id, orders.order_numFROM customers LEFT JOIN ordersON customers.cust_id = orders.cust_id;

右连接(RIGHT JOIN)

SELECT customers.cust_id, orders.order_numFROM customers RIGHT JOIN ordersON customers.cust_id = orders.cust_id;

组合(UNION)

组合查询

SELECT cust_name, cust_contact, cust_emailFROM customersWHERE cust_state IN ('IL', 'IN', 'MI')UNIONSELECT cust_name, cust_contact, cust_emailFROM customersWHERE cust_name = 'Fun4All';

JOIN vs UNION

五、函数

标签:语句,查询,cust,速成,user,SQL,手册,SELECT,name
来源: https://blog.csdn.net/agonie201218/article/details/122228689