mysql使用--表达式和函数

1.表达式
如:1+1,一般包含操作数,运算符。
_1.操作数
MYSQL中最常用的操作数有以下几种
(1).常数
(2).列名,针对某个具体的表,它的列名可被当作表达式的一部分
(3).函数调用
一个函数用于完成某个特定的功能。比如NOW()获取当前时间。
(4).其他表达式
一个表达式也可作为一个操作数与另一个操作数形成一个更复杂的形式。

_2.运算符
常用的有
(1).算术运算符

运算符示例描述
+a+b加法
-a-b减法
*a*b乘法
/a/b除法
DIVa DIV b除法,取商的整数部分
%a%b取余
--a取负值

DIV取商的整数部分,/会保留小数部分。
(2).比较运算符

运算符示例解释
=a=b等于
<=>a<=>b等于(NULL值安全等于)
<>或!=a<>b不等于
<a<b小于
<=a<=b小于或等于
>a>b大于
>=a>=b大于等于
BETWEENa BETWEEN b AND ca需满足b<=a<=c
NOT BETWEENa NOT BETWEEN b AND ca需不满足b<=a<=c
INa IN (b1, b2)a是b1,b2中的某个
NOT INa NOT IN (b1, b2, b3)a不是b1,b2中的某个
IS NULLa IS NULL
IS NOT NULLa IS NOT NULL
LIKEa LIKE ba匹配b
NOT LIKEa NOT LIKE b不匹配

比较表达式结果要么1TRUE),要么0FALSE
(3).逻辑运算符

运算符示例描述
NOT(也可写作!)NOT a对a取反
AND(也可写作&&)a AND b
OR(也可写作
XORa XOR ba和b有且只有一个为真时,表达式为真

_3.表达式的使用
_3.1.作为计算字段放在SELECT子句中
如:SELECT number, score+100 FROM student_score;
还有像这样的:SELECT 1, 'a' FROM student_score;
查询处理为:
(1).基于FROM结合WHERE得到结果集。
(2).对结果集每一行结合SELECT语句得到最终集中一行结果。

_3.2.作为搜索条件放在WHERE子句
基于FROME结合WHERE得到结果集时,对FROM得到表的每一行采用WHERE表达式,结果为TRUE,此行加入结果集。

_3.3.表达式中的NULL
_3.3.1.NULL作为算术符的操作数时,表达式的结果都为NULL
如:1+NULL结果是NULLNULL*1结果也是NULL
_3.3.2.除<=>IS NULLIS NOT NULL外,NULL作为其余比较运算符的操作数时,表达式的结果都为NULL
如:1=NULL结果是NULL2>NULL结果是NULL
IS NULLIS NOT NULL用于判断某个值是否为NULL,结果只能是01
<=>的操作数不包含NULL时,等价于=;当<=>的一个操作数为NULL,另一个不为NULL时,结果为0;两个操作数都为NULL时,结果为1

2.函数
_1.字符串处理函数

名称调用示例结果描述
LEFTLEFT(‘abc123’, 3)abc提取左边指定长度串
RIGHTRIGHT(‘abc123’, 3)123
LENGTHLENGTH(‘abc’)3
LOWERLOWER(‘ABC’)abc
UPPERUPPER(‘abc’)ABC
LTRIMLTRIM(’ abc’)abc
RTRIMRTRIM('abc ')abc
SUBSTRINGSUBSTRING(‘abc123’, 2, 3)bc1
CONCATCONCAT(‘abc’, ‘123’, ‘xyz’)abc123xyz
CHAR_LENGTHCHAR_LENGTH(‘狗哥’)2给定字符串的字符数量

_2.日期和时间处理函数

名称示例结果描述
NOWNOW()2021-05-11 17:10:43当前日期和时间
CURDATECURDATE()2021-05-11
CURTIMECURTIME()17:10:43
DATEDATE(‘2021-05-11 17:10:43’)2021-05-11将给定日期和时间值的日期提取出来
DATE_ADDDATE_ADD(‘2021-05-11 17:10:43’, INTERVAL 2 DAY)2021-05-13 17:10:43
DATE_SUBDATE_SUB(‘2021-05-11 17:10:43’, INTERVAL 2 DAY)2021-05-09 17:10:43
DATEDIFFDATEDIFF(‘2021-05-11’, ‘2021-05-17’)-6
DATE_FORMATDATE_FORMAT(NOW(), ‘%m-%d-%Y’)05-11-2021
YEARYEAR(‘2021-05-11 17:10:43’)2021
MONTHMONTH(‘2021-05-11 17:10:43’)5
DAYDAY(‘2021-05-11 17:10:43’)11
HOURHOUR(‘2021-05-11 17:10:43’)17
MINUTEMINUTE(‘2021-05-11 17:10:43’)10
SECONDSECOND(‘2021-05-11 17:10:43’)43

_2.1.使用DATE_ADDDATE_SUB时,可自定义增加或减去的时间间隔的单位。

单位描述
MICROSECOND毫秒
SECOND
MINUTE分钟
HOUR小时
DAY
WEEK星期
MONTH
QUARTER季度
YEAR

如:SELECT DATE_ADD('2021-05-11 17:10:43', INTERVAL 2 MINUTE)

_2.2.使用DATE_FORMAT需注意,可通过一些所谓的格式符来自定义日期和时间的显示格式。

格式符含义
%b简写的月份名称(Jan、、、)
%D带英文后缀的月份中的日期(0th,1st,…)
%d数字格式的月份中的日期(00,01,…)
%f微妙(000000~999999)
%H24小时制的小时(00~23)
%h12小时制的小时(01~12)
%i数值格式的分钟(00~59)
%M月份名(January,…)
%m数值形式的月份(00~12)
%p上午或下午(AM代表上午,PM代表下午)
%S秒(00~59)
%s秒(00~59)
%W星期名(Sunday,…)
%w周内第几天(0=星期日,…)
%Y4位数字形式的年(例如2019)
%y2位数字形式的年(例如19)

_2.3.数值处理函数

名称示例结果描述
ABSABS(-1)1
PiPI()3.141593
COSCOS(PI())-1
SINSIN(PI())1
TANTAN(0)0
POWPOW(2, 2)4
SQRTSQRT(9)3
MODMOD(5, 2)1
RANDRAND()0.7537623539136372
CEILCEIL(2.3)3
FLOORFLOOR(2.3)2

_2.4.流程控制表达式和函数
CASE WHEN 表达式1 THEN 结果1 [WHEN 表达式2 THEN 结果2 …] [ELSE 默认结果] END
如:SELECT number, score, CASE WHEN score < 60 THEN '不及格' WHEN score < 90 THEN '及格' ELSE '优秀' END As level FROM student_score;

CASE表达式还有第二种形式:
CASE 待比较表达式 WHEN 表达式1 THEN 结果1 [WHEN 表达式2 THEN 结果2 …] [ELSE 默认结果] END
它的含义是:
(1).待比较表达式值和表达式1值相同时,整个CASE值是结果1
(2).待比较表达式值和表达式2值相同时,整个CASE值是结果2

(3).待比较表达式值和所有WHEN后的表达式值都不同,则整个CASE表达式的值就是ELSE之后的默认结果。
如:SELECT name, department, CASE deparement WHEN '计算机学院' THEN '1级学科' WHEN '航天学院' THEN '2级学科' END AS 学院类别 FROM student_info;

CASE语句外,还可用下面三个函数进行条件判断。
(1).IF(表达式1, 表达式2, 表达式3)
含义为:表达式1TRUE时,返回值为表达式2;否则为表达式3
(2).IFNULL(表达式1, 表达式2)
含义为:当表达式1NULL时,返回值为表达式2;否则为表达式1
(3).NULLIF(表达式1, 表达式2)
含义为:当表达式1值和表达式2值相同时,返回值为NULL;否则为表达式1

_2.5.汇总函数
_1.常见函数
(1).MAX(表达式)
(2).MIN(表达式)
(3).SUM(表达式)
(4).AVG(表达式)
(5).COUNT(表达式)
上述函数的原理是,先从表运算得到结果集1,结果集1通过WHERE过滤得到结果集2,对结果集2的每一行执行汇总函数。结果集2中所有行处理完毕后,得到一个最终结果。
_2.汇总函数中DISTINCT的使用
如:SELECT COUNT(DISTINCT major) FROM student_info;
这样,结果集2中相同的表达式即使出现在多行,也只参与一次汇总函数运算。
_3.使用多个汇总函数
如:SELECT COUNT(*) AS 成绩记录总数, MAX(score) AS 最高成绩, MIN(score) AS 最低成绩, AVG(score) AS 平均成绩 FROM student_score;

3.隐式类型转换
_1.将操作数类型转换为运算符需要的类型
如:SELECT 1+2, '1'+2, '1'+'2'结果中每一列都是数值3
一些字符串转换成数值的举例:"12a"-->12,"2019-01"-->2019,"abc"-->0
_2.将函数参数转换成该函数期望的类型
指的是实参被转换为形参所需类型。
如:CONCAT('1', '2'),CONCAT('1', 2),CONCAT(1, 2)结果都是'12'。
_3.在WHERE子句中,单独的字符串类型的表达式会被转换为DOUBLE类型的数值。
_4.存储数据时,把某个值转换为某个列需要的类型
类似与实参转换为形参。
注意的是,向表中插入记录时,发生字符串的表达式转换为DOUBLE时,不可产生截断。
'12a'->12产生截断,因为存在字符a未参与转换。
'12'->12未产生截断,因为所有字符都参与了转换。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
MySQL正则达式是一种用于匹配和操作字符串的强大工具。它可以在MySQL数据库中进行模式匹配、搜索、替换等操作。在MySQL中,我们可以使用正则达式来查找符合特定模式的数据。 以下是一些常用的MySQL正则达式操作: 1. REGEXP:该操作符可用于在查询中使用正则达式进行模式匹配。例如,可以使用`SELECT * FROM table_name WHERE column_name REGEXP 'pattern'`来查找符合特定模式的数据。 2. REGEXP_LIKE:该函数用于检查一个字符串是否与给定的正则达式相匹配。例如,可以使用`SELECT * FROM table_name WHERE REGEXP_LIKE(column_name, 'pattern')`来查找符合特定模式的数据。 3. REGEXP_REPLACE:该函数用于将匹配到的字符串替换为新的字符串。例如,可以使用`SELECT REGEXP_REPLACE(column_name, 'pattern', 'replacement') FROM table_name`来替换符合特定模式的字符串。 4. REGEXP_INSTR:该函数用于返回一个字符串中第一个匹配项的位置。例如,可以使用`SELECT REGEXP_INSTR(column_name, 'pattern') FROM table_name`来获取符合特定模式的字符串的位置。 5. REGEXP_SUBSTR:该函数用于提取符合特定模式的子字符串。例如,可以使用`SELECT REGEXP_SUBSTR(column_name, 'pattern') FROM table_name`来提取符合特定模式的子字符串。 请注意,MySQL正则达式的语法可以使用标准的正则达式语法,但也有一些特定的规则和限制。在使用正则达式时,建议参考MySQL官方文档以了解更多详细信息和示例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

raindayinrain

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值