4 sql语法基础

news2025/1/11 14:51:06
1、DISTINCT

相同值只会出现一次。它作用于所有列,也就是说所有列的值都相同才算相同。

2、LIMIT

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

SELECT *
FROM mytable
LIMIT 5;
//========================
SELECT *
FROM mytable
LIMIT 5;

返回第 3 ~ 5 行:

SELECT *
FROM mytable
LIMIT 2, 3;
3、排序

ASC : 升序(默认)
ASC : 升序(默认)
可以按多个列进行排序,并且为每个列指定不同的排序方式:

SELECT *
FROM mytable
ORDER BY col1 DESC, col2 ASC;
4、过滤
注意:NULL0、空字符串都不同。
SELECT *
FROM mytable
WHERE col IS NULL;
5、通配符

通配符也是用在过滤语句中,但它只能用于文本字段

1. % 匹配 >=0 个任意字符;
2. _ 匹配 ==1 个任意字符;
3. [ ] 可以匹配集合内的字符,例如 [ab] 将匹配字符 a 或者 b。用脱字符 ^ 可以对其进行否定,也就是不匹配集合内的字符。

使用 Like 来进行通配符匹配。

SELECT *
FROM mytable
WHERE col LIKE '[^AB]%'; -- 不以 AB 开头的任意文本

注意:不要滥用通配符,通配符位于开头处匹配会非常慢。

6、计算字段

在数据库服务器上完成数据的转换和格式化的工作往往比客户端上快得多,并且转换和格式化后的数据量更少的话可以减少网络通信量。
计算字段通常需要使用 AS 来取别名,否则输出的时候字段名为计算表达式。

SELECT col1 * col2 AS alias
FROM mytable;

CONCAT() 用于连接两个字段。许多数据库会使用空格把一个值填充为列宽,因此连接的结果会出现一些不必要的空格,使用 TRIM() 可以去除首尾空格。

SELECT CONCAT(TRIM(col1), '(', TRIM(col2), ')') AS concat_col
FROM mytable;
7、函数

汇总函数如下:
在这里插入图片描述
AVG() 会忽略 NULL 行
使用 DISTINCT 可以让汇总函数值汇总不同的值

SELECT AVG(DISTINCT col1) AS avg_col
FROM mytable;

文本处理函数
在这里插入图片描述
其中, SOUNDEX() 可以将一个字符串转换为描述其语音表示的字母数字模式

SELECT *
FROM mytable
WHERE SOUNDEX(col1) = SOUNDEX('apple')
8、日期和时间处理
1.日期格式: YYYY-MM-DD
2.时间格式: HH:MM:SS

在这里插入图片描述

9、分组
1.分组就是把具有相同的数据值的行放在同一组中
2.可以对同一分组数据使用汇总函数进行处理,例如求分组数据的平均值等。
3.指定的分组字段除了能按该字段进行分组,也会自动按该字段进行排序
SELECT col, COUNT(*) AS num
FROM mytable
GROUP BY col;

GROUP BY 自动按分组字段进行排序,ORDER BY 也可以按汇总字段来进行排序。

SELECT col, COUNT(*) AS num
FROM mytable
GROUP BY col
ORDER BY num;

WHERE 过滤行,HAVING 过滤分组,行过滤应当先于分组过滤

SELECT col, COUNT(*) AS num
FROM mytable
WHERE col > 2
GROUP BY col
HAVING num >= 2;

分组规定:

1.GROUP BY 子句出现在 WHERE 子句之后,ORDER BY 子句之前;
2.除了汇总字段外,SELECT 语句中的每一字段都必须在 GROUP BY 子句中给出;
3.NULL 的行会单独分为一组;
4.大多数 SQL 实现不支持 GROUP BY 列具有可变长度的数据类型。
10、子查询
1.子查询中只能返回一个字段的数据
2.可以将子查询的结果作为 WHRER 语句的过滤条件
SELECT *
FROM mytable1
WHERE col1 IN (SELECT col2
               FROM mytable2);

下面的语句可以检索出客户的订单数量,子查询语句会对第一个查询检索出的每个客户执行一次:

SELECT cust_name, (SELECT COUNT(*)
                   FROM Orders
                   WHERE Orders.cust_id = Customers.cust_id)
                   AS orders_num
FROM Customers
ORDER BY cust_name;
11、连接
1.连接用于连接多个表,使用 JOIN 关键字,并且条件语句使用 ON 而不是 WHERE
2.连接可以替换子查询,并且比子查询的效率一般会更快。

内连接
内连接又称等值连接,使用 INNER JOIN 关键字。

    SELECT A.value, 
           B.value
      FROM tablea AS A 
INNER JOIN 
           tableb AS B
        ON A.key = B.key;
-- 可以不明确使用 INNER JOIN,而使用普通查询并在 WHERE 中将两个表中要连接的列用等值方法连接起来
SELECT A.value, 
       B.value
 FROM tablea AS A, 
      tableb AS B
WHERE A.key = B.key;

自连接

-- 1.自连接可以看成内连接的一种,只是连接的表是自身而已
-- 一张员工表,包含员工姓名和员工所属部门,要找出与 Jim 处在同一部门的所有员工姓名
SELECT name
FROM employee
WHERE department = (
      SELECT department
      FROM employee
      WHERE name = "Jim");
-- 自连接版本如下:
    SELECT 
		   e1.name
  	  FROM employee AS e1 
INNER JOIN employee AS e2
        ON e1.department = e2.department
       AND e2.name = "Jim";

自然连接

-- 1.自然连接是把同名列通过等值测试连接起来的,同名列可以有多个
-- 2.内连接和自然连接的区别: 内连接提供连接的列,而自然连接自动连接所有同名列。
SELECT A.value, B.value
FROM tablea AS A NATURAL JOIN tableb AS B;

外连接

-- 1.外连接保留了没有关联的那些行。分为左外连接,右外连接以及全外连接,左外连接就是保留左表没有关联的行
-- 2.检索所有顾客的订单信息,包括还没有订单信息的顾客。
SELECT Customers.cust_id, 
       Orders.order_num
FROM Customers LEFT OUTER JOIN Orders
ON Customers.cust_id = Orders.cust_id;
12、组合查询
-- 1.使用 UNION 来组合两个查询,如果第一个查询返回 M 行,第二个查询返回 N 行,那么组合查询的结果一般为 M+N 行
-- 2.每个查询必须包含相同的列、表达式和聚集函数
-- 3.默认会去除相同行,如果需要保留相同行,使用 UNION ALL
-- 4.只能包含一个 ORDER BY 子句,并且必须位于语句的最后
SELECT col
FROM mytable
WHERE col = 1
UNION
SELECT col
FROM mytable
WHERE col =2;
13、视图
-- 1.视图是虚拟的表,本身不包含数据,也就不能对其进行索引操作
-- 2.对视图的操作和对普通表的操作一样。
-- 3.视图具有如下好处:
   --(1)视图具有如下好处:
   --(2)只使用实际表的一部分数据;
   --(3)只使用实际表的一部分数据;
   --(4)更改数据格式和表示
CREATE VIEW myview AS
SELECT Concat(col1, col2) AS concat_col, col3*col4 AS compute_col
FROM mytable
WHERE col5 = val;
14、存储过程
-- 1.存储过程可以看成是对一系列 SQL 操作的批处理
-- 2.使用存储过程的好处:
  --(1)代码封装,保证了一定的安全性
  --(2)代码复用
  --(3)由于是预先编译,因此具有很高的性能

命令行中创建存储过程需要自定义分隔符,因为命令行是以 ; 为结束符,而存储过程中也包含了分号,因此会错误把这部分分号当成是结束符,造成语法错误。

-- 1.包含 in、out 和 inout 三种参数
-- 2.给变量赋值都需要用 select into 语句。
-- 3.给变量赋值都需要用 select into 语句。
delimiter //

create procedure myprocedure( out ret int )
    begin
        declare y int;
        select sum(col1)
        from mytable
        into y;
        select y*y into ret;
    end //

delimiter ;
-- 调用
call myprocedure(@ret);
select @ret;
15、游标
  1. 在存储过程中使用游标可以对一个结果集进行移动遍历。
  2. 游标主要用于交互式应用,其中用户需要对数据集中的任意行进行浏览和修改。
  3. 使用游标的四个步骤:
    (1)声明游标,这个过程没有实际检索出数据;
    (2)打开游标
    (3)取出数据
    (4)关闭游标
delimiter //
create procedure myprocedure(out ret int)
    begin
        declare done boolean default 0;

        declare mycursor cursor for
        select col1 from mytable;
        # 定义了一个 continue handler,当 sqlstate '02000' 这个条件出现时,会执行 set done = 1
        declare continue handler for sqlstate '02000' set done = 1;

        open mycursor;

        repeat
            fetch mycursor into ret;
            select ret;
        until done end repeat;

        close mycursor;
    end //
 delimiter ;
16、触发器
  1. 触发器会在某个表执行以下语句时而自动执行: DELETE、INSERT、UPDATE。
  2. 触发器必须指定在语句执行之前还是之后自动执行,之前执行使用 BEFORE 关键字,之后执行使用 AFTER 关键字。BEFORE 用于数据验证和净化,AFTER 用于审计跟踪,将修改记录到另外一张表中。
  3. INSERT 触发器包含一个名为 NEW 的虚拟表。
  4. DELETE 触发器包含一个名为 OLD 的虚拟表,并且是只读的。
  5. UPDATE 触发器包含一个名为 NEW 和一个名为 OLD 的虚拟表,其中 NEW 是可以被修改的,而 OLD 是只读的。
  6. MySQL 不允许在触发器中使用 CALL 语句,也就是不能调用存储过程。
CREATE TRIGGER mytrigger AFTER INSERT ON mytable
FOR EACH ROW SELECT NEW.col into @result;

SELECT @result; -- 获取结果
17、权限管理

MySQL 的账户信息保存在 mysql 这个数据库中

USE mysql;
SELECT user FROM user;

创建账户
新创建的账户没有任何权限

CREATE USER myuser IDENTIFIED BY 'mypassword';
**```
修改账户名**

```sql
RENAME myuser TO newuser;

删除账户

DROP USER myuser;

查看权限

SHOW GRANTS FOR myuser;

授予权限
账户用 username@host 的形式定义,username@% 使用的是默认主机名

GRANT SELECT, INSERT ON mydatabase.* TO myuser;

删除权限

-- GRANT 和 REVOKE 可在几个层次上控制访问权限:
-- 1.整个服务器,使用 GRANT ALL 和 REVOKE ALL
-- 2.整个数据库,使用 ON database.*
-- 3.特定的表,使用 ON database.table
-- 4.特定的列
-- 5.特定的存储过程
REVOKE SELECT, INSERT ON mydatabase.* FROM myuser;

更改密码
必须使用 Password() 函数

SET PASSWROD FOR myuser = Password('new_password');

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1168852.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

FFmpeg直播能力更新计划与新版本发布

// 编者按:客户端作为直接面向用户大众的接口,随着技术的发展进化与时俱进,实现更好的服务是十分必要的。FFmpeg作为最受欢迎的视频和图像处理开源软件,被相关行业的大量用户青睐,而随着HEVC标准的发布到广泛使用&am…

Canvas雷达显示图,动态扫描

做卫星项目的时候&#xff0c;会涉及到雷达图&#xff0c;用于扫描卫星&#xff0c;给人形象化的感觉。以下代码为canvas实现的demo&#xff0c;请运行查看. 效果图 源代码 <!DOCTYPE html> <html lang"zh"><head><meta charset"UTF-8&qu…

路由器基础(十二):IPSEC VPN配置

一、IPSec VPN基本知识 完整的IPSec协议由加密、摘要、对称密钥交换、安全协议四个部分组成。 两台路由器要建立IPSecVPN连接&#xff0c;就需要保证各自采用加密、摘要、对称密钥 交换、安全协议的参数一致。但是IPSec协议并没有确保这些参数一致的手段。 同时&#xff0c;IP…

【C语法学习】11 - fprintf()函数

文章目录 1 函数原型2 参数3 返回值4 比较5 示例 1 函数原型 fprintf()&#xff1a;将格式化输出发送至指定流stream&#xff0c;函数原型如下&#xff1a; int fprintf(FILE *stream, const char *format, ...)2 参数 fprintf()函数参数包括三部分&#xff1a; 参数stream…

Json工具类

工具类 package com.wego.controller;import cn.dev33.satoken.annotation.SaIgnore; import cn.dev33.satoken.stp.StpUtil; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.goog…

C++ Package继承层次,采用继承实现快递包裹的分类计价(分为空运2日达、陆运3日达)。

一、问题描述&#xff1a; Package继承层次&#xff0c;采用继承实现快递包裹的分类计价&#xff08;分为空运2日达、陆运3日达&#xff09;。自定义一个或多个快递公司&#xff0c;自定义计价方法&#xff0c;设计合适、合理的界面文本提示&#xff0c;以广东省内某市为起点&…

『 MySQL数据库 』之数据库基础

文章目录 mysql的登陆选项什么是数据库mysql与mysqld的区别mysql与数据库为什么存储数据时不用文件而用数据库? 在Linux中如何显式观察数据库?在Linux中如何使用mysql建立一个数据库,建立一张表结构,插入一些数据;服务器与数据库、表之间的关系SQL分类 mysql的登陆选项 mysq…

httpclient工具类(支持泛型转换)

1、网上搜到的httpclient工具类的问题&#xff1a; 1.1、如下图我们都能够发现这种封装的问题&#xff1a; 代码繁杂、充斥了很多重复性代码返回值单一&#xff0c;无法拿到对应的Java Bean对象及List对象集合实际场景中会对接大量第三方的OPEN API&#xff0c;下述方法的扩展…

最亮那颗星的中年危机 —— 程序员的职场困境与破局

如果说最近的这十年国内市场什么工作是最受瞩目的&#xff0c;那么程序员绝对算得上是夜空中最闪亮的那颗星。 伴随科技的迅猛发展&#xff0c;计算机走进千家万户&#xff0c;智能终端深深融入每个人的生活&#xff0c;程序员这一职业群体也逐渐成为了现代社会中不可或缺的一…

分享一个抖音视频解析神器~

怎么样下载抖音视频&#xff1f;相信很多人都有过这样的困惑。作为一个资深短视频剪辑工作者&#xff0c;常常需要用到各种视频素材&#xff0c;其中不乏需要从抖音上下载的&#xff0c;因此我也尝试过许多下载工具&#xff0c;但是效果都不大满意&#xff0c;直到有一次朋友给…

最近面试者对接口测试的理解真把我给笑拥了~

&#x1f4e2;专注于分享软件测试干货内容&#xff0c;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; 如有错误敬请指正&#xff01;&#x1f4e2;交流讨论&#xff1a;欢迎加入我们一起学习&#xff01;&#x1f4e2;资源分享&#xff1a;耗时200小时精选的「软件测试」资…

建议收藏《2023华为海思实习笔试-数字芯片真题+解析》(附下载)

华为海思一直以来是从业者想要进入的热门公司。但是岗位就那么多&#xff0c;在面试的时候&#xff0c;很多同学因为准备不充分&#xff0c;与岗位失之交臂&#xff0c;无缘进入该公司。今天为大家带来《2023华为海思实习笔试-数字芯片真题解析》题目来源于众多网友对笔试的记录…

CSS基础知识点速览

1 基础认识 1.1 css的介绍 CSS:层叠样式表(Cascading style sheets) CSS作用&#xff1a; 给页面中的html标签设置样式 css写在style标签里&#xff0c;style标签一般在head标签里&#xff0c;位于head标签下。 <style>p{color: red;background-color: green;font-size…

路由器基础(五): OSPF原理与配置

开放式最短路径优先 (Open Shortest Path First,OSPF) 是一个内部网关协议 (Interior Gateway Protocol,IGP),用于在单一自治系统(Autonomous System,AS) 内决策路由。OSPF 适合小型、中型、较大规模网络。OSPF 采用Dijkstra的最短路径优先算法 (Shortest Pat…

Go Gin中间件

Gin是一个用Go语言编写的Web框架&#xff0c;它提供了一种简单的方式来创建HTTP路由和处理HTTP请求。中间件是Gin框架中的一个重要概念&#xff0c;它可以用来处理HTTP请求和响应&#xff0c;或者在处理请求之前和之后执行一些操作。 以下是关于Gin中间件开发的一些基本信息&am…

【计算机网络 - 自顶向下方法】第一章习题答案

P2 Question&#xff1a;   式 (1-1) 给出了经传输速率为 R 的 N 段链路发送长度为 L 的一个分组的端到端时延。 对于经过 N 段链路一个接一个地发送 P 个这样的分组&#xff0c;一般化地表示出这个公式。 Answer&#xff1a;    N ∗ L R \frac{N*L}{R} RN∗L​ 时&…

【移远QuecPython】EC800M物联网开发板的内置GNSS定位获取(北斗、GPS和GNSS)

【移远QuecPython】EC800M物联网开发板的内置GNSS定位获取&#xff08;北斗、GPS和GNSS&#xff09; 测试视频&#xff08;其中的恶性BUG会在下一篇文章阐述&#xff09;&#xff1a; 【移远QuecPython】EC800M物联网开发板的内置GNSS定位的恶性BUG&#xff08;目前没有完全的…

Python语言:容器操作知识点总结清单

容器通用操作表格&#xff1a; 列表知识点清单&#xff1a; 元组知识点清单&#xff1a; 字典知识点清单&#xff1a; 集合知识点清单&#xff1a; 字符串知识点清单&#xff1a; 说明&#xff1a;本次知识点总结可能会有遗漏&#xff0c;没有做到面面俱到。

联通智网科技正式入选国家级专精特新“小巨人”企业

近日&#xff0c;北京市经济和信息化局发布《第五批专精特新“小巨人”企业公告名单》&#xff0c;根据工业和信息化部发布的《工业和信息化部关于公布第五批专精特新“小巨人”企业和通过复核的第二批专精特新“小巨人”企业名单的通告》&#xff0c;联通智网科技股份有限公司…