6.5 条件判断函数

条件判断函数也被称为控制流程函数,根据满足的条件的不同,执行相应的流程,Mysql中进行条件判断的有IF,IFNULL,和CASE。

6.5.1 IF(expr,v1,v2)函数

IF(expr,v1,v2)如果表达式expr是true(expr<>0 and expr<>NULL),则IF()的返回值为v1,否则返回v2。IF()的返回值为数字或字符串值。

SELECT IF(1>2,2,3),IF(1<2,'YES','NO'),IF(STRCMP('TEST','TEST1'),'NO','YES');

如果v1或者v2中只有一个明确是NULL,则IF()函数的结果类型为非NULL表达式结果类型。

6.5.2 IF(v1,v2)函数

IFNULL(v1,v2)加入v1不为NULL,则IFNULL()的值为v1,否则返回值为v2,IFNULL的返回值是数字或者字符串。

SELECT IFNULL(1,2),IFNULL(NULL,10),IFNULL(1/0,'WRONG');

注意:1/0的结果为空,因此IFNULL(1/0,'wrong')返回wrong.

6.5.3 CASE函数

CASE expr WHEN v1 THEN[WHEN v2 THEN r2][ELSE rn] END.

该函数表示,如果expr值等于某个vn,则返回对应THEN后面的结果,如果与所有值都不相同则返回ELSE后面的rn。

SELECT

CASE 5

WHEN 1 THEN

'one'

WHEN 2 THEN

'two'

ELSE

'more'

END;

CASE后面的值为2,与第二条分支语句WHEN后面的值相等,因此返回'two'。

SELECT

CASE

WHEN 1 < 0 THEN

'true'

ELSE

'false'

END;

1<0结果为false,因此函数返回值为ELSE后的'false'

6.6 系统信息函数

Mysql中的系统信息有,数据库的版本号、当前用户名和连接数、系统字符集、最后一个自动生成的ID值。

6.6.1 获取mysql中的版本号,连接数,数据库名的函数。

SELECT VERSION()

返回指示mysql服务器版本的字符串,这个字符串使用utf8字符集。

SELECT CONNECTION_ID()

SHOW PROCESSLIST;

6.6.2 获取用户名的函数

USER(),CURRENT_USER,CURRENT_USER(),SYSTEM_USER()和SESSION_USER()这几个函数返回当前被mysql服务器验证的用户名和主机名组合。一般情况下这几个函数返回值是相同的。

SELECT USER(),CURRENT_USER(),SYSTEM_USER();

6.6.3 获取字符串的字符集和排序方式的函数

SELECT

CHARSET('abc'),

CHARSET(CONVERT('abc' USING latin1)),

CHARSET(VERSION())

SELECT

collation('abc'),

COLLATION(CONVERT('abc' USING utf8))

6.6.4 获取最后一个自动生成的ID值的函数

LAST_INSERT_ID自动返回最后一个INSERT或者UPDATE为AUTO_INCREMENT列设置的第一个发生的值。

一次插入一条记录

INSERT INTO worker VALUES(NULL,'jimy');

INSERT INTO worker VALUES(NULL,'tony');

SELECT LAST_INSERT_ID();

一次同时插入多条

INSERT INTO worker VALUES(NULL,'kevry'),(NULL,'LILI'),(NULL,'miaomiao');

6.7 加密函数

加密函数主要用来对数据进行加密和界面处理以保证某些数据不被别人获取,这些数据在保证数据安全时非常有用。

6.7.1 加密函数PASSWORD(str)

PASSWORD(str)从原明文密码str计算并返回加密后的密码字符串,当参数为NULL时,返回NULL。

```

SELECT PASSWORD('newpwd');

```

PASSWORD函数在MYSQL服务器的鉴定系统中使用;不应该将它用在个人应用程序中。PASSWORD加密是单向的(不可逆)。PASSWORD()执行密码加密与Unix中密码被加密的方式不同。

6.7.2 加密函数MD5(str)

MD5(str)为字符串算出一个MD5 128比特校验和。该值以32位16进制数字的二进制字符串形式返回,若参数为NULL,则返回NULL。

```

SELECT MD5('mypwd');

```

6.7.3 加密函数ENCODE(str,pswd_str)

ENCODE(str,pswd_str)使用pswd_str作为密码,加密str。使用DECODE()解密结果,结果是一个和str长度相同的二进制字符串。

SELECT ENCODE('secret','cry'),LENGTH(ENCODE('secret','cry'));

可以看到加密后的显示结果为乱码,但加密后的长度和被加密字符串长度相同。

6.7.4 解密函数DECODE(crypt_str,pswd_str)

DECODE(crypt_str,pswd_str)使用pswd_str作为密码,解密加密字符串crypt_str,crypt_str是由ENCODE返回的字符串。

SELECT DECODE(ENCODE('secret','cry'),'cry');

可以看到,使用相同解密字符串进行解密之后的结果正好为ENCODE函数中被加密的字符串,DECODE函数和ENCODE函数互为反函数。

6.8 其他函数

6.8.1格式化函数FORMAT(x,n)

FORMAT(x,n)将数字x格式化,并以四舍五入的方式保留小数点后x位,结果以字符串的形式返回。若n为0,则返回结果函数不含小数部分。

```

SELECT FORMAT(122232.123456,4),FORMAT(122232.1,4),FORMAT(122232.2,0)

```

6.8.2 不同进制的数字进行转换函数 CONV(N,from_base,to_base)

CONV(N,from_base,to_base)进行不同进制间的转换。

6.8.3 IP地址与数字相互转换的函数INET_ATON(expr)

INET_ATON(expr) 给出一个作为字符串的网络地址,返回一个代表该地址数值的整数。地址可以是4或8比特地址。

SELECT INET_ATON('209.207.224.40');

INET_NTOA()将数值转为网络地址。

SELECT INET_NTOA(3520061480);

6.8.4 重复执行函数BENCHMARK(count,expr)

BENCHMARK(count,expr)函数重复count次执行表达式expr,它可以用于计算MYSQL处理表达式的速度。

SELECT PASSWORD('mypwd');

执行500000次PASSWORD函数的速度如下:

SELECT BENCHMARK(500000,PASSWORD('mypwd'));

6.9.1 数学函数

RAND()函数生成的随机数是在0-1之间,要生成0-10之间的随机数,RAND()需要乘以10,如果要求是整数,则还必须舍去结果的小数部分,这里使用ROUND()函数:

```

SELECT ROUND(RAND()*10);

```

6.9.2 如何从日期时间值中获取年月日等部分日期或者时间值?

MYSQL中,日期时间值以字符串的形式存储在数据标中,因此可以使用字符串函数截取日期时间值的不同部分,例如某个名称为dt的字段有值“2020-10-21 10:21:31”,如果只需要获取年的值,可以输入LEFT(dt,4),这样就获得了字符串左边开始长度为4的子字符串,即YEAR部分的值;

如果要获取月份,可以输入MID(dt,6,2)字符串第6个字符开始,长度为2的子字符串正好为月份值。

mysql case 2个返回值_MySQL函数简介 2相关推荐

  1. mysql 函数返回值_MySQL函数--(1)

    /* 函数与存储过程的区别 1.存储过程:可以有0个返回值,可以有多个返回值 函数:有且仅有一个返回值 */ #创建语法 create FUNCTION 函数名(参数列表) return 返回类型 B ...

  2. mysql正删改查返回值_MySQL增删改查

    1.MySQL安装教程 2.登录MySQL 选择zhaochao数据库,并查看user表中字段如下: 3.插入数据 3.1插入方法一 insert into user (id,username,use ...

  3. mysql c 调用存储过程返回值_Mysql:使用返回值调用存储过程

    我试图使用这个过程: DELIMITER $$ CREATE DEFINER=`root`@`localhost` PROCEDURE `sp_login`( IN in_Email VARCHAR( ...

  4. Swift2.0语言教程之函数的返回值与函数类型

    Swift2.0语言教程之函数的返回值与函数类型 Swift2.0中函数的返回值 根据是否具有返回值,函数可以分为无返回值函数和有返回值函数.以下将会对这两种函数类型进行讲解. Swift2.0中具有 ...

  5. python函数+定义+调用+多返回值+匿名函数+lambda+高级函数(reduce、map、filter)

    python函数+定义+调用+多返回值+匿名函数+lambda+高级函数(reduce.map.filter) Python 中函数的应用非常广泛,比如 input() .print().range( ...

  6. vb获得mysql的值,VB.NET调用MySQL存储过程并获得返回值的方法

    本文实例讲述了VB.NET调用MySQL存储过程并获得返回值的方法.分享给大家供大家参考.具体实现方法如下: Dim myConnectionString As String = "Data ...

  7. android 调用js怎么获取返回值_js 函数

    函数是一个特殊的对象 具名函数 function 函数名(形式参数1,形式参数2){ 语句 return 返回值 } 匿名函数 上门的具名函数,去掉函数名就是匿名函数 let a =function( ...

  8. 【C 语言】C 项目开发代码规范 ( 形参合法性判断 | 函数返回值局部变量 | 函数中不用全局变量 | 函数中使用局部变量接收形参 | 函数返回值 | 形参作返回值 | 形参返回值处理 )

    文章目录 一.C 项目开发代码规范 一.C 项目开发代码规范 上一篇博客 [C 语言]字符串模型 ( 键值对模型 ) 中 , 完成了字符串的 键值对 查找功能 , 代码不太规范 ; C 项目开发代码规 ...

  9. Python基础day05【函数(局部变量、全局变量、多函数执行流程、函数返回值、函数参数)、拆包、引用、可变与不可变类型、函数注意事项】

    视频.源码.课件.软件.笔记:超全面Python基础入门教程[十天课程]博客笔记汇总表[黑马程序员] Python基础day05[函数(函数传参的两种形式.函数形参).拆包.引用.可变与不可变类型.引 ...

最新文章

  1. rpm 安装 忽略依赖_解决RPM包依赖关系
  2. 【前沿技术】“中国天眼”观测到宇宙极端爆炸起源证据
  3. Jenkins插件之VShpere Cloud
  4. 两个子集pom互相调用_声明式服务调用组件Feign
  5. SQL Server 漏洞评估工具
  6. npm设置和取消代理的方法
  7. php 字符串串联_正确完成字符串串联操作-第2部分-一种有效的技术
  8. php将abc转换成整形是什么意思,php强制转换类型的方法
  9. 如何成为一名出色的架构师?
  10. MM32F3277替换STM32
  11. python重写和重载的区别_(C#)重载和重写的区别
  12. java osm pbf_read format .osm.pbf from geofabrik
  13. 下载RoboWare Studio官网登录不上去
  14. MybatisPlus 分页排序封装
  15. grapher_概述所有Grapher链接和Collection2模式
  16. flutter获取图片大小的Widget(网络图片大小,本地图片大小)
  17. 实得打印机色带芯更换
  18. 《Universal Language Model Fine-tuning for Text Classification》翻译
  19. 六行python代码的爱心曲线_6行python代码的爱心曲线
  20. ElasticSerach7.6.0拼音分词器安装和使用

热门文章

  1. 2018在职计算机科学硕士申请,2018年计算机专业硕士在职研究生备考指导
  2. hive 如何将数组转成字符串_hive 将hive表数据查询出来转为json对象和json数组输出...
  3. centeros下安装python
  4. NIO中的几个基础概念
  5. 在c语言中large的作用,输入两个数组,调用large函数比较,计数,输出统计结果...
  6. 单片机与普通微型计算机不同在于,单片机与普通计算机的不同之处在于什么,单片机与普通微型计算机的不同...
  7. mysql如何管理innodb元数据_1.1.20 可动态关闭InnoDB更新元数据的统计功能
  8. memset初始化类对象出错解析
  9. 树莓派环境处理_一种基于树莓派的便携式的环境监测系统的制作方法
  10. OpenShift 4.3 - 基于虚拟机的BareMetal离线安装(Shell说明)