SQL语句

    • 概括
    • 一.数据相关知识
      • 数据类型
      • 数据属性
    • 二.针对库的指令
      • 建库:creat
      • 删库:drop
      • 修改库:alter
    • 三.针对表的指令
      • 建表:creat
      • 修改表:alter
      • select(查找,选取)
      • distinct(返回唯一不同的值)
      • where(条件)
      • AND & OR 运算符
      • ORDER BY (对结果集进行排序)
      • INSERT INTO (向表格插入新的行)
      • Update (修改表中的数据)
      • DELETE(删除表中的行)
      • TOP(于规定要返回的记录的数目)
      • LIKE (在 WHERE 子句中搜索列中的指定模式)
      • SQL通配符
      • IN(允许我们在 WHERE 子句中规定多个值)
      • BETWEEN(选取介于两个值之间的数据范围)
      • Alias(为列名称和表名称指定别名)
      • Join (根据两个或多个表中的列之间的关系,从这些表中查询数据)
      • UNION(合并两个或多个 SELECT 语句的结果集)
      • SELECT INTO (可用于创建表的备份复件)
    • 四.SQL函数

概括

SQL 对大小写不敏感!
SQL DML 和 DDL
可以把 SQL 分为两个部分:数据操作语言 (DML) 和 数据定义语言 (DDL)。
查询和更新指令构成了 SQL 的 DML 部分:

SELECT - 从数据库表中获取数据
UPDATE - 更新数据库表中的数据
DELETE - 从数据库表中删除数据
INSERT INTO - 向数据库表中插入数据

SQL 的数据定义语言 (DDL) 部分使我们有能力创建或删除表格。我们也可以定义索引(键),规定表之间的链接,以及施加表间的约束。

SQL 中最重要的 DDL 语句:

CREATE DATABASE - 创建新数据库
ALTER DATABASE - 修改数据库
CREATE TABLE - 创建新表
ALTER TABLE - 变更(改变)数据库表
DROP TABLE - 删除表
CREATE INDEX - 创建索引(搜索键)
DROP INDEX - 删除索引

一.数据相关知识

数据类型

整型:
tinyint(m)	 最小整数 -128 ~ 127
smallint(m)  2个字节  范围(-32768~32767)
mediumint(m) 3个字节  范围(-8388608~8388607)
int(m) 		 4个字节  整数 -2^31 ~ 2^31 -1
bigint(m)    8个字节  范围(+-9.22*10的18次方)

字符串:
varchar:	字符类型 (变长)
char: 	 	字符类型 (定长)
enum:   	枚举类型
浮点型:
float(m,d):  单精度浮点数  8位精度(4字节)  m总个数,d小数位
double(m,d): 双精度浮点型  16位精度(8字节) m总个数,d小数位
日期时间类型:
date:        日期'2019-12-12'
time:        时间'12:30:30'
datetime:   时间类型 年月日时分秒
timestamp:   自动存储记录修改时间

数据属性

	null:                空(数据列可包含null值)
    not null: 			非空
	primary key: 		主键(唯一且非空的)
	auto_increment: 	自增(此列必须是:primary key或者unique key)
	unique key: 		单独的唯一的
	default: 			默认值
	unsigned: 			无符号,非负数
	character set name   指定一个字符集
	comment: 			注释

二.针对库的指令

建库:creat

删库:drop

修改库:alter

三.针对表的指令

建表:creat

creat table demo(id int);

creat table demo(
id int ,
name varchar(10)
cometime deatetime);

修改表:alter

#添加字段(默认添加到最后)

alter table student add 字段 varchar(10);

#在表头添加字段

alter table student add 字段 varchar(10) first;

#在指定字段之后添加字段

alter table student add 字段 varchar(10) after 字段;

#添加多个字段

alter table student add xiejun varchar(10),add lixin varchar(20);

#删除字段

alter table student drop xiejun;		

#修改字段的数据类型:(只能支持单个修改,不支持多个)

alter table student modify 字段 int;		

#修改字段名:

alter table student change lixin xiewang int;		

#修改字段名和数据类型

alter table student change xiewang lixin char(10);		

#修改表名

alter table student rename stu;

select(查找,选取)

语法:
SELECT 列名称 FROM 表名称
SELECT * FROM 表名称

实例
如需获取名为 “LastName” 和 “FirstName” 的列的内容(从名为 “Persons” 的数据库表),请使用类似这样的 SELECT 语句:

SELECT LastName,FirstName FROM Persons

distinct(返回唯一不同的值)

语法:
SELECT DISTINCT 列名称 FROM 表名称

如果在结果集中,某相同元素被列出了两次。
如需从 Company" 列中仅选取唯一不同的值,我们需要使用 SELECT DISTINCT 语句:

SELECT DISTINCT Company FROM Orders 

where(条件)

语法
SELECT 列名称 FROM 表名称 WHERE 列 运算符 值

下面的运算符可在 WHERE 子句中使用:

操作符 	描述
= 		等于
<>(!=) 	不等于
> 		大于
< 		小于
>= 		大于等于
<= 		小于等于
BETWEEN 在某个范围内
LIKE 	搜索某种模式

如果只希望选取居住在城市 “Beijing” 中的人,我们需要向 SELECT 语句添加 WHERE 子句:

//SQL 使用单引号来环绕文本值(大部分数据库系统也接受双引号)。如果是数值,请不要使用引号。
SELECT * FROM Persons WHERE City='Beijing'

AND & OR 运算符

AND 和 OR 可在 WHERE 子语句中把两个或多个条件结合起来。

如果第一个条件和第二个条件都成立,则 AND 运算符显示一条记录。

如果第一个条件和第二个条件中只要有一个成立,则 OR 运算符显示一条记录。
使用 AND 来显示所有姓为 “Carter” 并且名为 “Thomas” 的人:

SELECT * FROM Persons WHERE FirstName='Thomas' AND LastName='Carter'

使用 OR 来显示所有姓为 “Carter” 或者名为 “Thomas” 的人:

SELECT * FROM Persons WHERE firstname='Thomas' OR lastname='Carter'

我们也可以把 AND 和 OR 结合起来(使用圆括号来组成复杂的表达式):

SELECT * FROM Persons WHERE (
FirstName='Thomas' OR FirstName='William')
AND LastName='Carter'

ORDER BY (对结果集进行排序)

ORDER BY 语句默认按照升序对记录进行排序。
如果您希望按照降序对记录进行排序,可以使用 DESC 关键字。

以字母顺序显示公司名称:

SELECT 列1,2 From Orders ORDER BY Compny

以逆字母顺序显示公司名称,并以数字顺序显示顺序号:

SELECT Company, OrderNumber FROM Orders ORDER BY Company DESC, 
OrderNumber ASC

INSERT INTO (向表格插入新的行)

语法

INSERT INTO 表名称 VALUES (1,2,....)

我们也可以指定所要插入数据的列:

INSERT INTO table_name (1,2,...) VALUES (1,2,....)

Update (修改表中的数据)

语法:

UPDATE 表名称 SET 列名称 = 新值 WHERE 列名称 = 某值

为 lastname 是 “Wilson” 的人添加 firstname:

UPDATE Person SET FirstName = 'Fred' WHERE LastName = 'Wilson' 

DELETE(删除表中的行)

语法

DELETE FROM 表名称 WHERE 列名称 =

“Fred Wilson” 会被删除:

DELETE FROM Person WHERE LastName = 'Wilson' 

TOP(于规定要返回的记录的数目)

MySQL 语法

SELECT column_name(s)
FROM table_name
LIMIT number

例子

SELECT *
FROM Persons
LIMIT 5

LIKE (在 WHERE 子句中搜索列中的指定模式)

语法

SELECT column_name(s)
FROM table_name
WHERE column_name LIKE pattern

例子 1

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

//"%" 可用于定义通配符(模式中缺少的字母)
SELECT * FROM Persons
WHERE City LIKE 'N%'

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

SELECT * FROM Persons
WHERE City NOT LIKE '%lon%'

SQL通配符

在搜索数据库中的数据时,SQL 通配符可以替代一个或多个字符。
SQL 通配符必须与 LIKE 运算符一起使用。
在 SQL 中,可使用以下通配符:

通配符 		描述
% 			替代一个或多个字符
_ 			仅替代一个字符
[charlist] 	字符列中的任何单一字符

[^charlist]
或者		不在字符列中的任何单一字符
[!charlist]
				

例子 1

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

SELECT * FROM Persons
WHERE City LIKE '[ALN]%'

IN(允许我们在 WHERE 子句中规定多个值)

语法

SELECT column_name(s)
FROM table_name
WHERE column_name IN (value1,value2,...)

现在,我们希望从上表中选取姓氏为 Adams 和 Carter 的人:
我们可以使用下面的 SELECT 语句:

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

BETWEEN(选取介于两个值之间的数据范围)

语法

SELECT column_name(s)
FROM table_name
WHERE column_name
BETWEEN value1 AND value2

如需以字母顺序显示介于 “Adams”(包括)和 “Carter”(不包括)之间的人,请使用下面的 SQL:

//如需使用上面的例子显示范围之外的人,请使用 NOT BETWEEN操作符:
SELECT * FROM Persons
WHERE LastName
BETWEEN 'Adams' AND 'Carter'

Alias(为列名称和表名称指定别名)

别名使查询程序更易阅读和书写。

表的 SQL Alias 语法

SELECT column_name(s)
FROM table_name
AS alias_name

列的 SQL Alias 语法

SELECT column_name AS alias_name
FROM table_name

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

SELECT po.OrderID, p.LastName, p.FirstName
FROM Persons AS p, Product_Orders AS po
WHERE p.LastName='Adams' AND p.FirstName='John'

不使用别名的 SELECT 语句:

SELECT Product_Orders.OrderID, Persons.LastName, Persons.FirstName
FROM Persons, Product_Orders
WHERE Persons.LastName='Adams' AND Persons.FirstName='John'

Join (根据两个或多个表中的列之间的关系,从这些表中查询数据)

引用两个表(主键和外键要相同)

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

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

使用 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 类型,以及它们之间的差异。

JOIN: 如果表中有至少一个匹配,则返回行
LEFT JOIN: 即使右表中没有匹配,也从左表返回所有的行
RIGHT JOIN: 即使左表中没有匹配,也从右表返回所有的行
FULL JOIN: 只要其中一个表中存在匹配,就返回行

UNION(合并两个或多个 SELECT 语句的结果集)

请注意,UNION 内部的 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每条 SELECT 语句中的列的顺序必须相同。

语法

//这个命令无法列出在中国和美国的所有雇员。在上面的例子中,
//我们有两个名字相同的雇员,他们当中只有一个人被列出来了。
//UNION 命令只会选取不同的值。
SELECT column_name(s) FROM table_name1
UNION
SELECT column_name(s) FROM table_name2

UNION ALL 命令和 UNION 命令几乎是等效的,不过 UNION ALL 命令会列出所有的值。

SELECT INTO (可用于创建表的备份复件)

SELECT INTO 语句从一个表中选取数据,然后把数据插入另一个表中。
SELECT INTO 语句常用于创建表的备份复件或者用于对记录进行存档。

语法

您可以把所有的列插入新表:

SELECT *
INTO new_table_name [IN externaldatabase] 
FROM old_tablename

或者只把希望的列插入新表:

SELECT column_name(s)
INTO new_table_name [IN externaldatabase] 
FROM old_tablename

四.SQL函数

更多推荐

SQL基础语句总结