MySQL函数---常用函数和聚合函数

本文介绍了数学运算、字符串处理、时间日期、聚合函数、MD5加密以及SQL查询技巧,涵盖了基础到高级的数据库操作和数据处理方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

常用函数

  • 数学运算
SELECT ABS(-5)  --绝对值
SELECT CEILING(5.2) --向上取整
SELECT FLOOR(5.2) --向下取整
SELECT RAND() --返回一个 0~1 之间的随机数
  • 字符串函数
SELECT CHAR_LENGTH('有志者事竟成') --返回字符串长度
SELECT CONCAT('有','志者','事竟成') --拼接字符串
SELECT INSERT('有志事竟成',2,1,'志者') --返回(有志者事竟成)
SELECT LOWER('AbcD') --返回全为小写字母
SELECT UPPER('AbcD') --返回全为大写字母
SELECT INSTR('bajbhhd','a') --返回'a'第一次出现的索引
SELECT REPLACE('有志者事竟成','志','智')--替换指定的字符串,返回(有智者事竟成)
SELECT SUBSTR('有志者事竟成',2,2) --志者
SELECT REVERSE('有志者事竟成') --反转,返回(成竟事者志有)
--查询所有姓张的同学,将张替换为常
SELECT REPLACE(name,'张','常') FROM `student` WHERE name like '张%'
  • 时间和日期函数
SELECT CURRENT_DATE() --获取当前日期(2020-12-28)
SELECT CURDATE() --获取当前日期(2020-12-28)
SELECT NOW()--获取当前时间(2020-12-28 17:02:21)
SELECT LOCALTIME()--获取本地时间(2020-12-28 17:02:39)
SELECT SYSDATE()--获取系统时间(2020-12-28 17:03:00)
SELECT YEAR(NOW()) --获取年
SELECT MONTH(now())--获取月
SELECT DAY(NOW())--获取日
SELECT HOUR(NOW())--获取时
SELECT MINUTE(NOW())--获取分
SELECT SECOND(NOW())--获取秒
--系统相关
SELECT SYSTEM_USER() 
SELECT USER()
SELECT VERSION()

聚合函数(重点)

函数名称描述
count()计数
sum()求和
avg()平均值
max()最大值
min()最小值
--统计一个表中有多少个数据(count())
SELECT COUNT(`name`) FROM student --忽略所有的null值
SELECT COUNT(*) FROM student  --不会忽略null值,本质是计算行数
SELECT COUNT(1) from student  --不会忽略所有的null值,本质是计算行数
SELECT SUM(`age`) as 年龄总和 FROM `student`
SELECT AVG(`age`) as 平均年龄 FROM `student`
SELECT MAX(`age`) as 最大年龄 FROM `student`
SELECT MIN(`age`) as 最小年龄 FROM `student` 

数据库级别的MD5加密

  • MD5:MD5信息摘要算法(英语:MD5 Message-Digest Algorithm),一种被广泛使用的密码散列函数,可以产生出一个128位(16字节)的散列值(hash value),用于确保信息传输完整一致。
  • MD5主要增强算法复杂度和不可逆性
  • MD5破解网站的原理其实是背后有一个字典,对应加密前的值和加密后的值
--不加密时
INSERT into `student` VALUES (7,'D',10,'123456'),(8,'E',11,'123456')

--加密时
UPDATE `student` SET password=MD5(password) WHERE id=1
UPDATE `student` SET password=MD5(password)--加密全部的密码

--插入的时候加密
INSERT INTO `student` VALUES(9,'F',12,MD5('123456'))

--如何校验:将用户传递进来的密码,进行MD5加密,然后比对加密后的值
SELECT * FROM `student` WHERE `name`='F' and `password`=MD5('123456')

select 完整语法总结

select 去重 要查询的字段 from--表和字段可以取别名
xxx join 要连接的表 on 等值判断
where (具体的值,子查询语句)
group by (通过那个字段来分组)
having (过滤分组后的信息,条件和where是一样的,位置不同)
order by...(通过那个字段排序)--升序/降序
limit startIndex,pagesize
### 回答1: MySQL 数据库中可以使用聚合函数来对查询结果进行统计分析。常用聚合函数包括:COUNT()、SUM()、AVG()、MIN()、MAX()。 例如,在一个订单表中,想要统计订单总数,可以使用如下语句: ``` SELECT COUNT(*) FROM orders; ``` 如果想要统计订单总额,可以使用如下语句: ``` SELECT SUM(amount) FROM orders; ``` 若想对某个字段求平均值,可以使用AVG函数,例如: ``` SELECT AVG(price) FROM products; ``` 更多详细用法可以参考MySQL 官方文档。 ### 回答2: MYSQL数据库中的聚合函数可以对数据进行汇总计算。聚合函数一般用于统计或者分析数据,如查询总、平均值、最大值、最小值、计数等。 聚合函数有很多种,常用的包括SUM、AVG、MAX、MINCOUNT等。这些函数可以用于单个列或多个列,也可以与WHERE子句一起使用,从而实现更精确的数据查询分析。 例如,假设我们有一个名为Students的表,其中包含学生的姓名、性别、年龄成绩等信息。我们可以使用聚合函数来查询这些学生平均年龄成绩的总。 查询平均年龄: SELECT AVG(age) FROM Students; 查询成绩总: SELECT SUM(score) FROM Students; 我们还可以将聚合函数与GROUP BY子句一起使用,以对每个组进行聚合,进一步分析统计数据。例如,我们可以按性别分组并计算每个性别的平均年龄成绩总。 按性别分组查询平均年龄成绩总: SELECT gender, AVG(age), SUM(score) FROM Students GROUP BY gender; 聚合函数在数据分析统计方面非常有用。通过熟练掌握这些函数的使用方法,我们可以更好地理解分析数据,以便做出更有意义的决策。 ### 回答3: MySQL数据库是一种现代的关系型数据库管理系统,常用于Web应用程序开发中存储管理数据。在MySQL中,聚合函数可以帮助我们对数据进行统计分析。聚合函数可以对数据库中的数据进行处理,并返回聚合数据的结果。 MySQL常用聚合函数包括AVG()、SUM()、COUNT()、MAX()MIN()。这些函数可以用于单个列或多个列,以及一些特定条件限制。 AVG()函数用于计算一个列中所有值的平均值,例如: SELECT AVG(column_name) FROM table_name; SUM()函数用于计算一个列中所有值的总,例如: SELECT SUM(column_name) FROM table_name; COUNT()函数用于计算一个列中值的数目,例如: SELECT COUNT(column_name) FROM table_name; MAX()函数用于计算一个列中最大值,例如: SELECT MAX(column_name) FROM table_name; MIN()函数用于计算一个列中最小值,例如: SELECT MIN(column_name) FROM table_name; 在MySQL中,你可以在一个查询语句中使用多个聚合函数,并使用GROUP BY子句对结果进行分组。GROUP BY子句通常配合聚合函数使用,可对结果集按照一个或多个列进行分组。例如: SELECT column_name1, COUNT(column_name2), MAX(column_name3) FROM table_name GROUP BY column_name1; 此查询将根据column_name1对表table_name进行分组,并显示每组的计数最大值。 总之,聚合函数MySQL数据库中的一个强大工具,它可以帮助开发人员实现高效的数据统计分析,以更好地理解使用数据。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值