SQL函数和高级语句

news2025/1/24 14:38:49

目录

 

一、常用函数

1.聚合函数

2.数学函数

3.字符串函数

二、sql高级语句

1. SELECT(显示表格中指定字段或所有记录)

2.DISTINCT(不显示指定字段数据重复的记录) 

3.WHERE(指定条件查询)

4.AND、OR(条件且、或)

5.IN(显示字段指定的值的数据记录)

6.BETWEEN...AND...(显示字段指定的两个值范围内的数据记录)

7.通配符(常在like的模式中使用)

8.LIKE(查找指定模式范围的记录)

9.ORDER BY(按关键字排序)

10. GRUOP BY(对GROUP BY后面的字段的查询结果进行汇总分组)

11.HAVING(用来过滤由GROUP BY语句返回的记录集,通常与GROUP BY语句联合使用)

12.别名(字段别名,表格别名)

13.子查询(连接表格,在WHERE子句或HAVING子句中插入另一个sql语句)

14.EXISTS(用来测试内查询有没有产生任何结果)

15.表连接(内连、左连、右连)

16.CREATE VIEW(视图可以被当作是虚拟表或存储查询)

17.UNITON(联集,将两个sql语句的结果合并起来)

18.空值(NULL)和无值(' ')的区别

19.CASE(是sql用来做为if then else 之类逻辑判断的关键字)

20.正则(使用正则表达式查询内容)

21.存储过程(存储过程是一组为了完成特定功能的SQL语句集合)

(1)创建和使用

(2)查看存储过程信息

(3)查看存储过程创建信息

(4)删除存储过程

(5)含参存储过程的创建和使用


 

一、常用函数

1.聚合函数

平均价格 

非某一字段的条目数

所有记录条目数

去重记录条目数

最大最小价格 

价格总和 

2.数学函数

函数名用途
abs(x)返回x的绝对值
rand()返回0到1的随机数
mod(x,y)返回x除以y以后的余数
power(x,y)返回×的y次方
round(x)返回离x最近的整数
round(x, y)保留x的y位小数四舍五入后的值
sqrt(x)返回x的平方根
truncate (x, y)返回数字x截断为y位小数的值
ceil(x)返回大于或等于x的最小整数
floor(x)返回小于或等于x的最大整数
greatest(x1,x2,...)返回集合中最大的值,也可以返回多个字段的最大的值
least(x1,x2,...)返回集合中最小的值,也可以返回多个字段的最小的值

3.字符串函数

拼接字符串 

 如果sql模块中有PIPES_AS_CONCAT,也可以使用 || 拼接字符串

截取字符串

替换字符串 

去除开头和结尾的字符串

二、sql高级语句

以下两张表用于sql高级语句的演示

商品表

商品分类表

1. SELECT(显示表格中指定字段或所有记录)

SELECT `字段名` FROM `表名`;

                     *      代表所有字段

2.DISTINCT(不显示指定字段数据重复的记录) 

SELECT DISTINCT `字段名` FROM `表名`;

3.WHERE(指定条件查询)

 SELECT * FROM `表名` WHERE 条件表达式;

4.AND、OR(条件且、或)

SELECT * FROM `表名` WHERE 条件1 [AND 条件2] [OR 条件3];

5.IN(显示字段指定的值的数据记录)

SELECT * FROM `表名` WHERE `字段名` [NOT] IN ('值1','值2'); 

6.BETWEEN...AND...(显示字段指定的两个值范围内的数据记录)

SELECT * FROM `表名` WHERE `字段名` BETWEEN '值1' AND '值2';

7.通配符(常在like的模式中使用)

%  百分号表示零个、一个或多个字符

_   下划线表示单个字符

8.LIKE(查找指定模式范围的记录)

SELECT * FROM `表名` WHERE `字段名` LIKE '通配符模式';

9.ORDER BY(按关键字排序)

SELECT * FROM `表名` [WHERE 条件表达式] ORDER BY `字段` [ASC / DESC];

                                                                                              ASC 按升序排(不添加为默认)

                                                                                           DESC 按降序排

10. GRUOP BY(对GROUP BY后面的字段的查询结果进行汇总分组)

        通常是结合聚合函数一起使用的,凡是在GROUP BY后面出现的字段,必须在SELECT后面出现;凡是在 SELECT后面出现的、且未在聚合函数中出现的字段,必须出现在 GROUP BY后面。

SELECT `字段名` [聚合函数(`字段名`)] FROM `表名` GROUP BY `字段名`;

11.HAVING(用来过滤由GROUP BY语句返回的记录集,通常与GROUP BY语句联合使用)

        HAVING 语句的存在弥补了WHERE关键字不能与聚合函数联合使用的不足。

SELECT `字段名` [聚合函数(`字段名`)] FROM `表名` GROUP BY `字段名` HAVING 条件;

12.别名(字段别名,表格别名)

SELECT [表格别名.]`字段名` [AS] 字段别名 FROM `表名` [AS] 表别名;

13.子查询(连接表格,在WHERE子句或HAVING子句中插入另一个sql语句)

 SELECT `字段1` FROM `表1名` WHERE `字段2` [比较运算符] ( SELECT `字段1` FROM `表2名` WHERE 条件表达式);

比较运算符:可以是符号的运算符,例如=、>、<、>=、<= ;也可以是文字的运算符,例如 LIKE、IN、BETWEEN。

14.EXISTS(用来测试内查询有没有产生任何结果)

        如果有的话,系统就会执行外查询中的sql语句;若是没有的话,那整个sql语句就不会产生任何结果。

15.表连接(内连、左连、右连)

inner join (内连接):只返回两个表中联结字段相等的行;
left join (左连接):返回包括左表中的所有记录和右表中联结字段相等的记录;

right join (右连接):返回包括右表中的所有记录和左表中联结字段相等的记录。

SELECT * FROM `表1名` A INNER JOIN `表2名` B ON A.`字段`=B.`字段`; 

         `字段`...                       LEFT JOIN

                                             RIGHT JOIN

16.CREATE VIEW(视图可以被当作是虚拟表或存储查询)

        视图跟表格的不同是,表格中有实际储存数据记录,而视图是建立在表格之上的一个架构,它本身并不实际储存数据记录。临时表在用户退出或同数据库的连接断开后就自动消失了,而视图不会消失。

        视图不含有数据,只存储它的定义,它的用途一般可以简化复杂的查询。比如你要对几个表进行连接查询,而且还要进行统计排序等操作,写sql语句会很麻烦,用视图将几个表联结起来,然后对这个视图进行查询操作,就和对一个表查询一样,很方便。

创建和查看视图表 

CREATE VIEW 视图表名 AS SELECT语句;

使用视图表

17.UNITON(联集,将两个sql语句的结果合并起来)

        两个sql语句所产生的字段需要是同样的数据记录种类;

        UNION 生成结果的数据记录值将没有重复,且按照字段的顺序进行排序;

        UNION ALL 将生成结果的数据记录值都列出来,无论有无重复。

SELECT语句1 UNION [ALL] SELECT语句2; 

18.空值(NULL)和无值(' ')的区别

无值的长度为0,不占用空间的;而 NULL值的长度是 NULL,是占用空间的。

IS NULL 或者 IS NOT NULL 是用来判断字段是不是为 NULL,不能查出是不是无值。

无值的判断使用=' '或者<>' '来处理。<>代表不等于。

在通过 count() 指定字段统计有多少行数时,如果遇到NULL值会自动忽略掉,遇到无值' '会加入到记录中进行计算。

19.CASE(是sql用来做为if then else 之类逻辑判断的关键字)

SELECT `字段1`,...,CASE (`判断字段`)

        WHEN 条件1 THEN 结果1        //条件可以是一个数值或公式

        WHEN 条件2 THEN 结果2

[ELSE] 结果n                    //ELSE子句不是必须的

END

FROM `表名`;

20.正则(使用正则表达式查询内容)

SELECT `字段` FROM `表名` WHERE `字段` REGEXP '正则表达式';

21.存储过程(存储过程是一组为了完成特定功能的SQL语句集合)

        存储过程在使用过程中是将常用或者复杂的工作预先使用sql语句写好并用一个指定的名称存储起来,这个过程经编译和优化后存储在数据库服务器中。当需要使用该存储过程时,只需要调用它即可。存储过程在执行上比传统sql速度更快、执行效率更高。

存储过程的优点

        执行一次后,会将生成的二进制代码驻留缓冲区,提高执行效率;

        SQL语句加上控制语句的集合,灵活性高;
        在服务器端存储,客户端调用时,降低网络负载;
        可多次重复被调用,可随时修改,不影响客户端调用;
        可完成所有的数据库操作,也可控制数据库的信息访问权限。

(1)创建和使用

--修改结束符为 $$--
delimiter $$

--创建存储过程--
create procedure proc1()
    -> begin
    -> insert into `goods` values ('可乐',3.5,'广州');
    -> delete from `goods` where `gname`='可乐';
    -> end$$

--将结束符修改回 ;--
delimiter ;

--使用存储过程--
call proc1;

(2)查看存储过程信息

(3)查看存储过程创建信息

(4)删除存储过程

DROP PROCEDURE [IF EXISTS] `存储进程名`;

(5)含参存储过程的创建和使用

传入参数 IN

传出参数 OUT

同时传入和传出参数 INOUT

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

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

相关文章

(五)「消息队列」之 RabbitMQ 主题(使用 .NET 客户端)

0、引言 先决条件 本教程假设 RabbitMQ 已安装并且正在 本地主机 的标准端口&#xff08;5672&#xff09;上运行。如果您使用了不同的主机、端口或凭证&#xff0c;则要求调整连接设置。 获取帮助 如果您在阅读本教程时遇到问题&#xff0c;可以通过邮件列表或者 RabbitMQ 社区…

【树链+EXGCD】杭电多校第一场 A

1001 Hide-And-Seek Game (hdu.edu.cn) 题意&#xff1a; 给定一棵树和两条路径&#xff0c;每条路径都有起点和终点&#xff0c;起始时起点有人&#xff0c;每隔一秒都会往终点走一步&#xff0c;会从起点走向终点再会起点这样不断地周期性地走&#xff0c;让你求一点&#…

线上 OOM 频发,MyBatis 有坑...

继上次线上 CPU 出现了报警&#xff0c;这次服务又开始整活了&#xff0c;风平浪静了没几天&#xff0c;看生产日志服务的运行的时候&#xff0c;频繁的出现 OutOfMemoryError&#xff0c;就是我们俗称的 OOM&#xff0c;这可还行&#xff01; 频繁的 OOM 直接会造成服务处于一…

编程小白的自学笔记十(python爬虫入门二+实例代码详解)

系列文章目录 编程小白的自学笔记九&#xff08;python爬虫入门代码详解&#xff09; 编程小白的自学笔记八&#xff08;python中的多线程&#xff09; 编程小白的自学笔记七&#xff08;python中类的继承&#xff09; 编程小白的自学笔记六&#xff08;python中类的静态方法…

pandas 笔记:pivot_table 数据透视表

1 基本使用方法 pandas.pivot_table(data, valuesNone, indexNone, columnsNone, aggfuncmean, fill_valueNone, marginsFalse, dropnaTrue, margins_nameAll, observedFalse, sortTrue)2 主要参数 dataDataFramevalues要进行聚合的列index在数据透视表索引&#xff08;index…

flask基本用法小白教程+按钮跳转到指定页面+python和pip安装(后附)

一、flask学习教程&#xff1a; 1.1 基本程序&#xff1a; 大家可以在pycharm中复制如下代码&#xff0c;先感受一下flask的基本用法&#xff1a; 点击链接可进入浏览器查看程序运行的结果&#xff0c;在127.0.0.1:5000后面添上/test1/等设定的文字&#xff0c;可查看不同函…

Python生成exe文件运行出现黑框闪退如何查看运行bug?

cmd进行回车 第一&#xff1a;进入到可执行exe文件目录&#xff0c;如下图所示 第二&#xff1a;输入可执行文件名&#xff0c;然后就会出现报错提示

(转载)BP神经网络的非线性系统建模(matlab实现)

1案例背景 在工程应用中经常会遇到一些复杂的非线性系统,这些系统状态方程复杂,难以用数学方法准确建模。在这种情况下,可以建立BP神经网络表达这些非线性系统。方法把未知系统看成是一个黑箱,首先用系统输入输出数据训练BP神经网络,使网络能够表达该未知函数,然后用训练好的 B…

【外卖系统】环境的搭建

搭建数据库 1.创建数据库&#xff0c;名字叫reiggie 2.导入数据库 创建Maven项目 1.创建项目 2.检查项目新建的是否有问题 3.导入pom.xml文件 4.导入application.yml文件 在从gittee上down的代码的基础上&#xff0c;修改一下端口号&#xff0c;数据库的名称什么的 …

(数组与矩阵) 剑指 Offer 29. 顺时针打印矩阵 ——【Leetcode每日一题】

❓ 剑指 Offer 29. 顺时针打印矩阵 难度&#xff1a;简单 输入一个矩阵&#xff0c;按照从外向里以顺时针的顺序依次打印出每一个数字。 示例 1&#xff1a; 输入&#xff1a;matrix [[1,2,3],[4,5,6],[7,8,9]] 输出&#xff1a;[1,2,3,6,9,8,7,4,5] 示例 2&#xff1a; 输…

DP转HDMI方案芯片-CS5218/CS5263/CS5363/CS5463详细参数对比说明

CS5218/CS5263/CS5363/CS5463都可用于设计DP转HDMI转接线方案&#xff0c;但几者间不管封装还是功能参数都有差异&#xff0c;如下介绍对比下&#xff1a; CS5218 DP to HDMI(4K30HZ) &#xff0c;CS5218管脚定义参数说明和设计电路图&#xff1a; ​ ​ CS5263 DP to HDMI 4…

Kubernetes_1.27.3_Harbor结合Nacos实战

Nacos 实战 作者:行癫(盗版必究) 一:Nacos简介 1.简介 ​ Nacos是 Dynamic Naming and Configuration Service的首字母简称,一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台;Nacos 致力于帮助您发现、配置和管理微服务;Nacos 提供了一组简单易用的特…

计讯物联5G千兆网关TG463在电力智能巡检机器人的应用功能解析

项目背景 随着国家智能电网建设加速推进&#xff0c;投资规模持续扩大&#xff0c;我国电网智能化、信息化不断提高&#xff0c;传统的电力运维与管理模式早已不能满足智能电网快速发展的需求。因此&#xff0c;在5G无线通信、人工智能、物联网、云计算、大数据、电力等前沿技术…

Error: The client is unauthorized due to authentication failure.解决办法

进入到neo4j的安装目录 修改neo4j.conf配置文件 把红框的注释#去掉保存后&#xff0c;重新运行neo4j,问题解决

【Python统计与数据分析实战_01】位置与分散程度的度量

数据描述性分析 1.描述统计量1.1 位置与分散程度的度量1.1.1 例子一 单维数组1.1.2 例子二 多维数组 1.2 关系度量1.3 分布形状的度量1.3.1 统计量&#xff1a;偏度和峰度 1.4 数据特性的总括 1.描述统计量 数据的统计分析分为统计描述和统计推断两部分。前者通过绘制统计图、…

Vue3.0的设计目标是什么?做了哪些优化?

一、设计目标 不以解决实际业务痛点的更新都是耍流氓,下面我们来列举一下Vue3之前我们或许会面临的问题 随着功能的增长,复杂组件的代码变得越来越难以维护 缺少一种比较「干净」的在多个组件之间提取和复用逻辑的机制 类型推断不够友好 bundle的时间太久了 而 Vue3 经过长达…

RuoYi-Vue/vue项目访问 webpack 中定义的变量

前言 RuoYi-Vue 3.8.4 webpack 中定义的变量 vue.config.js 中定义的 webpack 的变量 在html页面中&#xff0c;如何访问 webpack 的变量 <title><% webpackConfig.name %></title>参考&#xff1a;ruoyi-ui/public/index.html 文件

【分布式训练】基于Pytorch的分布式数据并行训练

基于Pytorch的分布式数据并行训练 动机为什么要并行分布数据&#xff1f;现有资料的不足 Outline整体框架图带解释的最小demo示例没有multiprocessing开启multiprocessing 分布式训练启动方式混合精度训练&#xff08;采用apex&#xff09; 参考资料 简介&#xff1a; 在PyTorc…

一则 MySQL 参数设置不当导致复制中断的故障案例

本文分享了一个数据库参数错误配置导致复制中断的问题&#xff0c;以及对参数配置的建议。 作者&#xff1a;秦福朗 爱可生 DBA 团队成员&#xff0c;负责项目日常问题处理及公司平台问题排查。热爱互联网&#xff0c;会摄影、懂厨艺&#xff0c;不会厨艺的 DBA 不是好司机&…

Linux学习之运算符

是赋值运算符&#xff0c;可以把一个变量设置上特定的值&#xff0c;而算术运算符就包括加减乘除&#xff08;、-、*、/&#xff09;&#xff0c;需要使用expr这个命令进行运算。 expr 5 7可以计算出来5与7的和&#xff0c;使用echo $?可以看到expr 5 7这个命令的返回值是0&…