Mysql函数

MySQL -函数

常用字符串函数SELECT...

函数

功能

CONCAT(S1,S2....Sn)

字符串拼接

LOWER(str)

将字符串str全部改成小写

UPPER(str)

将字符串str全部改成大写

LPAD(str,n,pad)

左填充,用字符串pad对str的左边进行填充,达到n个字符串长度

RPAD(str,n,pad)

右填充,用字符串pad对str的右边进行填充,达到n个字符串长度

TRIM(str)

去掉字符串头部和尾部的空格

SUBSTRING(str,start,len)

返回从字符串str从start位置起的len个长度的字符串

实例:

-- CONCAT拼接字符串

select CONCAT('hello', 'MySQL');

-- lower 全部转换小写

select lower('HELLO');

-- upper 全部转换大写

select upper('hello');

-- lpadz 左填充

select lpad('01',5,'-');

-- rpad 右填充

select rpad('01',5,'-');

-- TRIM  去掉字符串头部和尾部的空格

select trim(' HELLO world ');

-- SUBSTRING 返回从字符串str从start位置起的len个长度的字符串

select SUBSTRING('HELLO MYSQL',1,5);

练习:由于业务需求变更,企业员工的工号,统一为5位数,目前不足5位数的全部在前面补0。比如: 1号员工的工号应该为00001

update emp set wordno = lpad(wordno ,5,'0');

常用数值函数

函数

功能

CEIL(X)

向上取整

FLOOR(X)

向下取整

MOD(X,Y)

返回x/y的模

RAND()

返回0~1内的随机数

ROUND(X,Y)

求参数X的四舍五入的值,保留Y位小数

实例:

-- ceil() 向大取整

select ceil(1.2);

-- floor() 向下取整

select floor(1.2);

-- mod(x,y) 返回x/y的模(取余)

select MOD(5,2);

-- rand();

select rand();

-- round(X,Y)求参数X的四舍五入的值,保留Y位小数

select round(5.4556,2);

-- 通过数据库的函数,生成一个六位数的随机验证码。

select lpad(ceil(rand()*1000000),6,0);

MySQL--日期函数

函数

功能

CURDATE()

返还当前日期

CURTIME()

返还当前时间

NOW()

返还当前日期和时间

YEAR(DATE)

获取指定date的年份

MONTH(DATE)

获取指定date月份

DAY(DATE)

获取指定DATE的日期

DATE_ADD(DATE,INTERVAL EXPR TYPE)

返回一个日期/时间加上一个时间间隔expr后的时间值

DATEDIFF(DATE1,DATE2)

返回起始时间DATE1和结束时间DATE2之间的天数

实例 :

-- CURDATE()当前日期

select CURDATE();

-- CURTIME() 当前时间

SELECT CURTIME();

-- NOW()

SELECT NOW();

-- YEAR,MONTH,DAY获取指定date的年/月/日

SELECT YEAR(NOW());

SELECT MONTH(NOW());

SELECT DAY(NOW());

-- DATE_ADD(DATE,INTERVAL EXPR TYPE) 往后推的时间

SELECT DATE_ADD(NOW(),INTERVAL 70 DAY);

SELECT DATE_ADD(NOW(),INTERVAL 70 MONTH);

SELECT DATE_ADD(NOW(),INTERVAL 70 YEAR);

-- DATEDIFF(DATE1,DATE2) 两日期的差别

SELECT DATEDIFF(NOW(),'2020-11-11');

案例:查询所有员工的入职天数,并根据入职天数倒叙排序。

select name , datediff(now(),entrydate) as '入职天数'

from emp

order by '入职天数' desc;

流程控制函数

流程控制函数在SQL语句中实现条件筛选,从而提高语句的效率

函数

功能

IF(value,t,f)

如果value为true,则返回t,否则返回f

IFNULL(value1,value2)

如果value1不为空,返回value,否则返回value2

CASE WHEN [val1] THEN [res1] ... ELSE [default] END

如果value为true,返回res1,...否则返回default默认值

CASE [expr] WHEN [val1] THEN [res1] ... ELSE [default] END

如果expr的值等于val1,返回res1, ... 否则返回default默认值。

-- IF()

SELECT IF(TRUE,'OK','ERROR');

-- IFNULL(1,2)如果第一个值不为空就返回第一个值,否则返回第二个值

SELECT IFNULL('OK','DEFAULT');

SELECT IFNULL('','DEFAULT');

SELECT IFNULL(NULL,'DEFAULT');

-- case when then else end

-- 需求:查询emp表的员工姓名和年龄(18 --->刚成人 ,20 ---> 成人两年了,其他---> 其他)

select name,case age when 18 then '刚成人' when 20 then '成人两年了' else '其他' end

from emp;

案例:

统计班级冬个些员的成绩,展示的规则如下:>= 85展不优秀;>= 60,展示及格,否则展示不及格

select name,grade,case when grade >= 85 then '优秀' when grade >= 60 then '及格' else '不及格' end as'是否及格'

from emp;

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

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

相关文章

实验5-1 使用函数计算两个复数之积 (10 分)

本题要求现一个函数计算两个复数之积。 函数接口定义: double result_real, result_imag; void complex_prod( double x1, double y1, double x2, double y2 ); 其中用户传入的参数为两个复数x1y1i和x2y2i;函数complex_prod应将计算结果的实部存放在全局…

线程间的同步、如何解决线程冲突与死锁

一、线程同步概念: 线程同步是指在多线程编程中,为了保证多个线程之间的数据访问和操作的有序性以及正确性,需要采取一些机制来协调它们的执行。在多线程环境下,由于线程之间是并发执行的,可能会出现竞争条件&#xf…

【WebRTC---源码篇】(三:一)音频轨

音频轨的创建时序在Conductor::AddTracks()中 rtc::scoped_refptr<webrtc::AudioTrackInterface> audio_track(peer_connection_factory_->CreateAudioTrack(kAudioLabel, peer_connection_factory_->CreateAudioSource(cricket::AudioOptions()))); 通过代码我们…

el-upload批量手动上传,并用form表单校验上传文件

手动上传设置:auto-upload"false" <el-formref"formData"class"formWidth":model"formData"label-width"120px":rules"rules"><el-form-itemlabel"数据"class"uploadClass"required…

RadioButton基本使用

作用&#xff1a;单选框&#xff0c;一般用于设置或者选择某项任务。 常用属性&#xff1a; 常用事件&#xff1a; 选中事件 后台代码&#xff1a; private void radioButton1_CheckedChanged(object sender, EventArgs e){if (radioButton1.Checked){MessageBox.Show(radioB…

AcWing 4310:树的DFS ← vector、auto、邻接表

【题目来源】https://www.acwing.com/problem/content/description/4313/【题目描述】 给定一棵 n 个节点的树。 节点的编号为 1∼n&#xff0c;其中 1 号节点为根节点&#xff0c;每个节点的编号都大于其父节点的编号。 现在&#xff0c;你需要回答 q 个询问。 每个询问给定两…

电脑ADB连接手机的方式通过网络无法adb连接手机的问题(已解决)

首先电脑要下载adb工具&#xff0c;将压缩包解压到C盘&#xff1a;https://download.csdn.net/download/qq_43445867/87975072 1、使用USB线连接 打开手机USB调试&#xff1b;PC端安装手机USB驱动。 1.打开DOS命令窗口&#xff0c;进入adb文件夹,输入adb.exe devices回车列出设…

用shell实现MySQL分库分表操作

#!/bin/bash mysql_cmd-uroot -p123 #定义变量保存密码 exclude_dbinformation_schema|performance_schema|sys #数据库 bak_path/backup/db #备份路径 mysql ${mysql_cmd} -e show databases -N | egrep -v "${exclude_db}" > dbname while read line do …

企业内网终端安全无客户端准入控制技术实践

终端无代理/无客户端准入控制技术因其良好的用户体验而倍受创新企业的青睐。无代理/无客户端准入控制技术&#xff0c;顾名思义&#xff0c;是一种在网络中对终端实施访问控制的方法&#xff0c;无需依赖特定的客户端软件。 不同于银行、医院等传统行业的终端准入控制需求&…

Kubernetes(K8s)从入门到精通系列之八:部署K8s对软件、硬件、网络通信的要求

Kubernetes K8s从入门到精通系列之八:部署K8s对软件、硬件、网络通信的要求 一、系统要求二、K8s集群网络通信要求一、系统要求 K8s系统由一组可执行程序组成,用户可以通过K8s在GitHub的项目网站下载编译好的二进制文件或镜像文件,或者下载源码并自行将其编译为二进制文件。…

接口和抽象类的区别

https://blog.csdn.net/qq_58772217/article/details/121542021 https://www.sohu.com/a/367158483_468635 语法区别 抽象类只能单继承&#xff1b;接口可以多实现&#xff1b;接口的变量默认是public static final的&#xff0c;接口的方法默认是public&#xff1b;抽象类可以…

学术笔记|科技论文写作常用拉丁语词汇总结

本篇博客总结本人在学术论文阅读或写作过程中接触到的高频拉丁语词汇及常用短语。 目录 一、常用写作标记二、常用拉丁短语三、其他 一、常用写作标记 学术论文中使用频率较高的拉丁语缩写&#xff0c;结尾的 “.” 不要忘记加上&#xff0c;表示该词为缩写形式。 - etc. (et…

摄像头电池组和平衡车电池组

摄像头电池组 Wh~是电量 Wh V*Ah 毫安(mA)~是电流 电量是9.62Wh&#xff0c;电压是 3.7v 9.62 wh / 3.7v 2.6 Ah 2600mAH 4个并联电池&#xff1a;10400mAH / 4 2600mAH PH2.0mm-2Pins 平衡车 72 wh / 36v 2 Ah 2000mAH 对比自己买的单粒电池 vs 摄像头和平衡车的 …

java中io流、属性集Properties、缓冲流、转换流、序列化和反序列化、打印流、网络编程(TCP通信程序、文件复制案例、文件上传案例、B/S服务案例)

IO流&#xff1a; io流中i表示input输入&#xff0c;o表示output输出&#xff0c;流表示数据&#xff08;字符&#xff0c;字节&#xff0c;1个字符2个字节8个位&#xff09;&#xff1b;这里的输入输出是以内存为基础&#xff0c;将数据从内存中输出到硬盘的过程称为输出&…

【JavaEE初阶】博客系统后端

文章目录 一. 创建项目 引入依赖二. 设计数据库三. 编写数据库代码四. 创建实体类五. 封装数据库的增删查改六. 具体功能书写1. 博客列表页2. 博客详情页3. 博客登录页4. 检测登录状态5. 实现显示用户信息的功能6. 退出登录状态7. 发布博客 一. 创建项目 引入依赖 创建blog_sy…

ffmpeg.c源码与函数关系分析

介绍 FFmpeg 是一个可以处理音视频的软件&#xff0c;功能非常强大&#xff0c;主要包括&#xff0c;编解码转换&#xff0c;封装格式转换&#xff0c;滤镜特效。FFmpeg支持各种网络协议&#xff0c;支持 RTMP &#xff0c;RTSP&#xff0c;HLS 等高层协议的推拉流&#xff0c…

基于Java+SpringBoot+SpringCloud+Vue的智慧养老平台设计与实现(源码+LW+部署文档等)

博主介绍&#xff1a; 大家好&#xff0c;我是一名在Java圈混迹十余年的程序员&#xff0c;精通Java编程语言&#xff0c;同时也熟练掌握微信小程序、Python和Android等技术&#xff0c;能够为大家提供全方位的技术支持和交流。 我擅长在JavaWeb、SSH、SSM、SpringBoot等框架…

Opencv-C++笔记 (15) : 像素重映射 与 图像扭曲

文章目录 一、重映射简介二、图像扭曲 一、重映射简介 重映射&#xff0c;就是把一幅图像中某位置的像素放置到另一图像指定位置的过程。即&#xff1a; 在重映射过程中&#xff0c;图像的大小也可以同时发生改变。此时像素与像素之间的关系就不是一一对应关系&#xff0c;因…

TCP Socket 基础知识点(实例是以Java进行演示)

本篇根据TCP & Socket 相关知识点和学习所得进行整理所得。 文章目录 前言1. TCP相关知识点1.1 双工/单工1.2 TCP协议的主要特点1.3 TCP的可靠性原理1.4 报文段1.4.1 端口1.4.2 seq序号1.4.3 ack确认号1.4.4 数据偏移1.4.5 保留1.4.6 控制位1.4.7 窗口1.4.8 校验和1.4.9 紧…

VS+Qt环境下解决中文乱码问题

目录 原因解决方案总结 原因 使用VSQt出现中文乱码的情况一般都是给控件添加中文文本时出现&#xff0c;而控件需要的字符串类型是QString&#xff0c;默认是utf-8。在 Visual Studio 中&#xff0c;源代码文件的默认执行字符集可能是 Windows 默认的 ANSI 字符集&#xff0c;…