·SQL注释:
·单行注释:-注释内容(-后面一定要有一个空格)
·单行注释:#注释内容(#后面可以不加空格,推荐加上)
·多行注释:/注释内容/
数据插入INSERT
基础语法:
INSERT INTO表[(列1,列2,…,列N)]VALUES(值1,值2,…,值N)[,(值1,值2,
,值N),(值1,值2,.,值N)]
需要注意,sql中对字符串只能用单引号包围
DELETE
DELETE FROM table_Xxx WHERE 条件判断;
UPDATE
UPDATE 表名 SET 列=值 WHERE 条件;
分组聚合
基础语法:
SELECT 字段|聚合函数 FROM表[WHERE条件] GROUP BY列
聚合函数有:
-SUM(列)求和
-AVG(列)求平均值
-MIN(列)求最小值
-MAX(列)求最大值
-COUNT(列|*)求数量
需要注意的是,select字段中,非聚合结果字段必须在group by中出现,才能在前面select字段中出现
结果排序
可以对查询的结果,使用ORDER BY关键字,指定某个列进行排序,语法:
SELECT
列|聚合函数|*FROM 表
WHERE
GROUP BY…
ORDER BY … [ASC DESC]
默认ASC升序
结果限制及分页
SELECT 列|聚合函数|* FROM表
WHERE …
GROUP BY…
ORDER BY … [ASC DESC]
LIMIT n[,m]
这里如果n, m都有,那么n表示offset,我们也可以显式指定LIMIT n OFFSET m
执行顺序
多表查询-FROM多表
查询除了会使用1张表以外,可能会同时使用多张表,常见的多表查询方式有:
·FROM多表
·INNER JOIN
·OUTER JOIN
基础的FROM多表语法:
SELECT … FROM 表1 AS别名1, 表2 AS别名2, …, 表N [WHERE连接条件];
直接在FROM中写多个表,通过AS可以给出表别名(可以省略)
这种查询相当于先把多表的结果先全查出来做笛卡尔积再做过滤,效率比较低,可以用内关联或外关联更高效
INNER JOIN 内关联
SELECT … FR0M表1 AS 别名1 [INNER] J0IN 表2 AS别名2 0N 连接条件;
INNER是可以省略的,默认内关联,内关联是取两个表指定关联列交集
自连接
对同一张表中,想要得到广东省有哪些市,我们只在一张表中进行inner join即可,把一个表当城两个表使用
假设 表名为areas
select city.*from areas as city
inner join
areas as province
on city.pid=province.aid
where province.atitle=‘广东省’
外关联
语法:SELECT … FROM 表1 AS别名1 (LEFT RIGHT) [OUTER] J0IN 表2 AS别名2 0N连接条件;
·OUTER关键字可以省略
·外关联分左右,必须选择LEFT JOIN(左外关联)或者RIGHT JOIN(右外关联),二选一。
子查询
子查询:把一个查询的结果当做另一查询的条件
子查询分为三类:
标量子查询:子查询返回的结果是一个数据(一行一列)
列子查询:返回的结果是一列(一列多行)
行子查询:返回的结果是一行(一行多列)
实际使用时一般无需关注市行列还是标量。