一些mysql的基础

·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(右外关联),二选一。

子查询

子查询:把一个查询的结果当做另一查询的条件
子查询分为三类:
标量子查询:子查询返回的结果是一个数据(一行一列)
列子查询:返回的结果是一列(一列多行)
行子查询:返回的结果是一行(一行多列)

实际使用时一般无需关注市行列还是标量。

  • 12
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值