sql 汇总

完整sql手册

这个文档里有完整的sql教程,内容全面。本文只记录常见的内容。

简单语句

sql 执行顺序

示例

SELECT DISTINCT column, AGG_FUNC(column_or_expression)
FROM mytable
    JOIN another_table
      ON mytable.column = another_table.column
    WHERE constraint_expression
    GROUP BY column
    HAVING constraint_expression
    ORDER BY column ASC/DESC
    LIMIT count OFFSET COUNT;

1,FROM 和 JOINs
FROM 或 JOIN会第一个执行,确定一个整体的数据范围. 如果要JOIN不同表,可能会生成一个临时Table来用于 下面的过程。总之第一步可以简单理解为确定一个数据源表(含临时表)

2, WHERE
我们确定了数据来源 WHERE 语句就将在这个数据源中按要求进行数据筛选,并丢弃不符合要求的数据行,所有的筛选col属性 只能来自FROM圈定的表. AS别名还不能在这个阶段使用,因为可能别名是一个还没执行的表达式

3, GROUP BY
如果你用了 GROUP BY 分组,那GROUP BY 将对之前的数据进行分组,统计等,并将是结果集缩小为分组数.这意味着 其他的数据在分组后丢弃.

4,HAVING
如果你用了 GROUP BY 分组, HAVING 会在分组完成后对结果集再次筛选。AS别名也不能在这个阶段使用.

5,SELECT
确定结果之后,SELECT用来对结果col简单筛选或计算,决定输出什么数据.

6,DISTINCT
如果数据行有重复DISTINCT 将负责排重.

7,ORDER BY
在结果集确定的情况下,ORDER BY 对结果做排序。因为SELECT中的表达式已经执行完了。此时可以用AS别名.

8,LIMIT / OFFSET
最后 LIMIT 和 OFFSET 从排序的结果中截取部分数据.
————————————————
参考文章:https://blog.csdn.net/weixin_44912627/article/details/124290069

大小写

标准标识符和分隔标识符中的 ASCII 字母是不区分大小写的,并且会在数据库中转换为小写。默
认情况下,查询结果中的列名称以小写形式返回。要以大写形式返回列名称,请将 describe_field_name_in_uppercase 配置参数设置为 true。
一般windows系统中,不区分大小写,但管理员也可以调成区分大小写。linux系统是区分大小写的。

null 和exists

  • 要测试是否为 null,请使用比较条件 IS NULL 和 IS NOT NULL。由于 null 表示缺少数据,因此 null 不等于任何值或其他 null,用“=null"会导致整个select语句的返回结果都是空的。
  • EXISTS 条件测试子查询中是否存在行,并在子查询返回至少一个行时返回 true。如果指定 NOT,此条件将在子查询未返回任何行时返回 true。
select dateid from date
where exists (
select 1 from sales
where date.dateid = sales.dateid
)
order by dateid;

操作符

操作符 语法 描述

<	a < b	值 a 小于值 b。
>	a > b	值 a 大于值 b。
<=	a <= b	值 a 小于或等于值 b。
>=	a >= b	值 a 大于或等于值 b。
=	a = b	值 a 等于值 b。
<> 或 !=	a <> b or a != b	值 a 不等于值 b。
ANY | SOME	a = ANY(subquery)	值 a 等于子查询返回的任何值。
ALL	a <> ALL or != ALL (subquery))	值 a 不等于子查询返回的任何值。
IS TRUE | FALSE | UNKNOWN	a IS TRUE	值 a 是布尔值 TRUE。

abs绝对值;sum求和;avg平均值;sqrt平均根;

like和通配符

% 替代 0 个或多个字符
_ 替代一个字符

SELECT * FROM Websites
WHERE name LIKE 'G%'; #G开头的字符串

语句合并union all

union all 是不去重,而union是自动去重。

SELECT column_name(s) FROM table1
UNION ALL
SELECT column_name(s) FROM table2;

group by 和having

  • 1.where在group by前, having在group by 之后
  • 2.聚合函数(avg、sum、max、min、count),不能作为条件放在where之后,但可以放在having之后
SELECT Websites.name, SUM(access_log.count) AS nums 
FROM Websites
INNER JOIN access_log
ON Websites.id=access_log.site_id
WHERE Websites.alexa < 200 
GROUP BY Websites.name
HAVING SUM(access_log.count) > 200;

distinct

  • distinct只能在select中使用,必须放在开头第一个参数位置。
SELECT DISTINCT column_name,column_name
FROM table_name;

如果distinct后面有多个字段,则对多个字段进行去重,如果只对多个字段中某一个字段去重,可以使用下面的group_concat()。

group_concat

  • GROUP_CONCAT(xxx):是将分组中括号里对应的字符串进行连接.如果分组中括号里的参数xxx有多行,那么就会将这多行的字符串连接,每个字符串之间会有特定的符号进行分隔。
GROUP_CONCAT([DISTINCT] column1 [ORDER BY column2 ASC\DESC
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值