4 sql语法基础

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 col2FROM mytable2);

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

SELECT cust_name, (SELECT COUNT(*)FROM OrdersWHERE 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.valueFROM tablea AS A 
INNER JOIN tableb AS BON A.key = B.key;
-- 可以不明确使用 INNER JOIN,而使用普通查询并在 WHERE 中将两个表中要连接的列用等值方法连接起来
SELECT A.value, B.valueFROM tablea AS A, tableb AS B
WHERE A.key = B.key;

自连接

-- 1.自连接可以看成内连接的一种,只是连接的表是自身而已
-- 一张员工表,包含员工姓名和员工所属部门,要找出与 Jim 处在同一部门的所有员工姓名
SELECT name
FROM employee
WHERE department = (SELECT departmentFROM employeeWHERE name = "Jim");
-- 自连接版本如下:SELECT e1.nameFROM employee AS e1 
INNER JOIN employee AS e2ON e1.department = e2.departmentAND 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 )begindeclare y int;select sum(col1)from mytableinto 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)begindeclare done boolean default 0;declare mycursor cursor forselect col1 from mytable;# 定义了一个 continue handler,当 sqlstate '02000' 这个条件出现时,会执行 set done = 1declare continue handler for sqlstate '02000' set done = 1;open mycursor;repeatfetch 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.rhkb.cn/news/179975.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

绝地求生msvcp140.dll丢失报错怎么办,这四个方法都可以解决

在回答这个问题之前,我们先来了解一下什么是msvcp140.dll。msvcp140.dll是微软Visual C 2015 Redistributable的一个组件,它包含了许多运行库文件,用于支持各种应用程序的正常运行。当你在玩《绝地求生》(俗称“吃鸡”&#xff09…

gma 2 教程(三)坐标参考系统:3.投影方法

安装 gma:pip install gma 地图投影是利用一定数学法则把地球表面的经、纬线转换到平面上的理论和方法。由于地球是一个赤道略宽两极略扁的不规则的梨形球体,故其表面是一个不可展平的曲面,所以运用任何数学方法进行这种转换都会产生误差和变…

工地现场智慧管理信息化解决方案 智慧工地源码

智慧工地系统充分利用计算机技术、互联网、物联网、云计算、大数据等新一代信息技术,以PC端,移动端,设备端三位一体的管控方式为企业现场工程管理提供了先进的技术手段。让劳务、设备、物料、安全、环境、能源、资料、计划、质量、视频监控等…

【广州华锐互动】VR野外求生技能学习,让你感受真实的冒险之旅!

随着科技的迅速发展,虚拟现实(VR)技术为人们提供了一个全新的、身临其境的探险体验。通过将用户带入一个仿真的、沉浸式的虚拟环境,VR互动体验让人们在安全的氛围中感受到野外探险的乐趣。本文将从视觉呈现、沉浸式体验、交互性和应用范围四个方面&#…

堆栈与队列算法-以链表来实现队列

目录 堆栈与队列算法-以链表来实现队列 C代码 堆栈与队列算法-以链表来实现队列 队列除了能以数组的方式来实现外,也可以用链表来实现。在声明队列的类中,除了和队列相关的方法外,还必须有指向队列前端和队列末尾的指针,即fron…

图数据库Neo4j概念、应用场景、安装及CQL的使用

一、图数据库概念 引用Seth Godin的说法,企业需要摒弃仅仅收集数据点的做法,开始着手建立数据之间的关联关系。数据点之间的关系甚至比单个点本身更为重要。 传统的**关系数据库管理系统(RDBMS)**并不擅长处理数据之间的关系,那些表状数据模…

AI大模型架构师专家,你会问什么来测试我的水平,如何解答上述问题,学习路径是什么

0. 沈剑老师的大模型产品应用经验: 提示词三步骤: 假如我是xxx专家,你会问什么来测试我的水平;假如你是xxx专家,你会如何解答上述问题;假如你是xxx专家,上述问题的学习路径是什么;…

node使用http模块

文章目录 前言一、创建http服务二、设置http的响应报文三、不同请求响应不同数据四、请求响应不同html文件1. 添加www文件夹2. js代码3. 效果 五、get和post请求的区别 前言 提示:这里可以添加本文要记录的大概内容: 一、创建http服务 // 1&#xff1a…

【Redis】使用Java操作Redis

🎉🎉欢迎来到我的CSDN主页!🎉🎉 🏅我是Java方文山,一个在CSDN分享笔记的博主。📚📚 🌟推荐给大家我的专栏《Redis》。🎯🎯 &#x1f4…

【51单片机】串口与LED点阵屏(学习笔记)

一、串口 1、串口的概述 串口是一种应用十分广泛的通讯接口,串口成本低、容易使用、通信线路简单,可实现两个设备的互相通信。 单片机的串口可以使单片机与单片机、单片机与电脑、单片机与各式各样的模块互相通信,极大的扩展了单片机的应用…

jar包的精细化运营,Java模块化简介 | 京东云技术团队

图:模块化手机概念 一、什么是Java模块化 Java模块化(module)是Java9及以后版本引入的新特性。 官方对模块的定义为:一个被命名的,代码和数据的自描述集合。( the module, which is a named, self-descri…

k8s-服务网格实战-入门Istio

istio-01.png 背景 终于进入大家都比较感兴趣的服务网格系列了,在前面已经讲解了: 如何部署应用到 kubernetes服务之间如何调用如何通过域名访问我们的服务如何使用 kubernetes 自带的配置 ConfigMap 基本上已经够我们开发一般规模的 web 应用了&#xf…

Path with “WEB-INF“ or “META-INF“: [webapp/WEB-INF/NewFile.html]

2023-11-04 01:03:14.523 WARN 10896 --- [nio-8072-exec-6] o.s.w.s.r.ResourceHttpRequestHandler : Path with "WEB-INF" or "META-INF": [webapp/WEB-INFNewFile.html] spring.mvc.view.prefix:/webapp/WEB-INF/

ChatGLM3-6B详细安装过程记录(Linux)

先附上GitHub官方地址: https://github.com/THUDM/ChatGLM3https://github.com/THUDM/ChatGLM3 目录 一、预览 1. 基于 Gradio 的网页版 demo

Git客户端软件 Tower mac中文版特点说明

Tower mac是一款Mac OS X系统上的Git客户端软件,它提供了丰富的功能和工具,帮助用户更加方便地管理和使用Git版本控制系统。 Tower mac软件特点 1. 界面友好:Tower的界面友好,使用户能够轻松地掌握软件的使用方法。 2. 多种Git操…

uniapp小程序砸金蛋抽奖

砸之前是金蛋png图片&#xff0c;点击砸完之后切换砸金蛋动效gif图片&#xff1b; 当前代码封装为砸金蛋的组件&#xff1b; vue代码&#xff1a; <template><view class"page" v-if"merchantInfo.cdn_static"><image class"bg&qu…

【电路笔记】-相位差和相移

相位差和相移 文章目录 相位差和相移1、概述2、相位差2.1 同频信号2.2 电流与电压信号2.3 相似频率的信号 3、干扰4、总结 当我们听歌曲时&#xff0c;我们将正弦声音波形感知为音乐。 它们的振幅告诉我们信号有多大&#xff0c;频率告诉我们声音是低音还是高音。 然而&#xf…

超低价:阿里云双11服务器优惠价格表_87元一年起

2023阿里云双十一优惠活动已经开启了&#xff0c;轻量2核2G服务器3M带宽优惠价87元一年、2核4G4M带宽优惠价165元一年&#xff0c;云服务器ECS经济型e实例2核2G3M固定带宽优惠价格99元一年&#xff0c;还有2核4G、2核8G、4核8G、4核16G、8核32G等配置报价&#xff0c;云服务器e…

FRI及相关SNARKs的Fiat-Shamir安全

1. 引言 本文主要参考&#xff1a; Alexander R. Block 2023年论文 Fiat-Shamir Security of FRI and Related SNARKsAlbert Garreta 2023年9月在ZK Summit 10上分享 ZK10: Fiat-Shamir security of FRI and related SNARKs - Albert Garreta (Nethermind) 评估参数用的Sage…