MySQL字符串函数、日期时间函数
MySQL字符串函数、日期时间函数
一、常见字符串函数:
- 1、CHAR_LENGTH 获取长度(字符为单位)
- 2、FORMAT 格式化
- 3、INSERT 替换的方式插入
- 4、INSTR 获取位置
- 5、LEFT/RIGHT 取左、取右
- 6、LENGTH 获取长度(字节为单位)
- 7、LTRIM/RTRIM/TRIM 去空格(左/右/自定义)
- 8、STRCMP 字符串比较
- 9、CONCAT 字符串拼接
- 10、SUBSTRING 字符串截取
1、CHAR_LENGTH:获取长度(字符为单位)
CHAR_LENGTH(str)
解释:返回值为字符串str的长度,计算的单位为字符(一个中文也算一个字符)
举例:

如果是查询已知表格里的字段长度,可以这样写:

2、FORMAT:
FORMAT(X,D)
解释:将数字X的格式写为'#,###,###.##',以四舍五入的方式保留小数点后D位,并将结果以字符串的形式返回。若D为0, 则返回结果不带有小数点,或不含小数部分。
举例:

3、INSERT:替换的方式插入
INSERT (str,pos,len,newstr)
解释:返回字符串str,从原str的pos位置开始,用字符串newstr来替换,替换的长度为len。
如果pos超过字符串长度,则返回值为原始字符串。假如len的长度超过后面字符串的长度,则从位置pos开始替换到字符串的结尾即可。
四个参数中若任何一个参数为的值为null,则整个函数的返回值为NULL。
举例:将smyh001替换为smyh002

4、INSTR:查找子字符串的位置
INSTR(str,substr)
解释:返回字符串str中首次出现子字符串substr的位置。
举例:



5、LEFT/RIGHT:字符串截取
- 左截取:
LEFT(str,len)
解释:返回字符串str中,从左边开始算起的,前len个字符。
- 右截取:
RIGHT(str,len)
解释:返回字符串str中,从右边开始算起的,前len个字符。
6、LENGTH:求字符串长度(以字节为单位)
LENGTH(str)
解释:返回值为字符串str的长度,单位为字节。一个多字节字符算作多字节。这意味着对于一个包含五个2字节字符的字符串,LENGTH()的返回值为10,而CHAR_LENGTH()的返回值则为5。
注:
- GBK 编码中,一个中文字符是2个字节。
- UTF-8编码中,一个中文字符是3个字节,一个英文字符是2个字节。
7、LTRIM/RTRIM/TRIM 去空格(左/右/自定义):
- 去掉左边的空格:
LTRIM(str)
解释:返回字符串str,其引导空格字符被删除。
- 去掉中间的空格:
RTRIM(str)
解释:返回字符串str,其结尾空格字符被删除。
- 自定义去空格:
TRIM([{BOTH | LEADING | TRAILING} [remstr] FROM] str)
注:大括号和中括号里面的参数为可选项,如果全部都加上的话,默认为参数both。
解释:将原字符串str去掉空格返回。只去开头(leading)的空格,只去结尾(trailng)的空格,或者同时去掉(both)开头和结尾的空格都行。若分类符BOTH、LEADIN或TRAILING中没有一个是给定的,则假设为BOTH。
TRIM([remstr FROM] str)
解释:remstr关键字的作用是去掉指定字符。 即所有包含remstr的前缀和/或后缀将被删除。未指定情况下,即删除空格。
官方文档的举例:

8、STRCMP:判断字符串是否相等
STRCMP(expr1,expr2)
解释:判断两个字符串是否相等。若所有的字符串均相同,则返回0;若根据当前分类次序,第一个参数小于第二个,则返回-1;其它情况返回1。功能和比较器类似。
注:字符串的大小是按照ANSI编码来比较的。
举例:

9、CONCAT:字符串拼接
CONCAT(str1,str2,...)
解释:返回结果为连将str1、str2···拼接之后产生的字符串。如有任何一个参数为NULL ,则返回值为 NULL。括号里可能有一个或多个参数。
如果所有参数均为非二进制字符串,则结果为非二进制字符串。如果自变量中含有任意一个二进制字符串,则结果为一个二进制字符串。一个数字参数将自动转化为与之相等的二进制字符串格式。
若要避免这种情况二进制的情况出现,可使用显式类型 cast(str),将二进制的字符串转换为非二进制字符串。例如:SELECT CONCAT(CAST(int_col AS CHAR), char_col)
举例:(navicat编辑器会自动将二进制字符串转换为非二进制字符串)

10、SUBSTRING:字符串截取
SUBSTRING(str,pos) SUBSTRING(str FROM pos) SUBSTRING(str,pos,len) SUBSTRING(str FROM pos FOR len)
解释:不带有len 参数的格式从字符串str返回一个子字符串,起始于位置 pos。带有len参数的格式从字符串str返回一个长度同len字符相同的子字符串,起始于位置 pos。
使用FROM的格式为标准SQL语法。
也可能对pos使用一个负值。假若这样,则子字符串的位置起始于字符串结尾的pos字符(也就是说,pos为正时,从左边算起;pos为负时,从右边算起)。
官方文档举例如下:

二、常见日期时间函数:
- 1、DAYOFWEEK、 DAYOFYEAR、DAYOFMONTH
- 2、WEEKDAY
- 3、YEAR、QUARTER、MONTH、
- 4、HOUR、MINUTE、SECOND
- 5、TO DAYS、FROM DAYS
- 6、CURDATE、CURTIME、NOW 获取当前时间
1、DAYOFWEEK、 DAYOFYEAR、DAYOFMONTH
- 求星期几:(一周中的第几天)
DAYOFWEEK(date)
解释:返回date(1=周日,2=周一, ...,7=周六)对应的工作日索引。即:date对应的范围是1至7。
- 求一年中的某天是第几天:(一年中的第几天)
DAYOFYEAR(date)
返回date对应的一年中的天数,范围是从1到366。
- 求一个月中的某天是第几天:(一个月的第几天)
DAYOFMONTH(date)
返回date对应的该月日期,范围是从1到31。注:DAY(date) 和DAYOFMONTH(date)的含义相同。
举例:




2、WEEKDAY:
- 求星期几:(一周的第几天)
WEEKDAY(date)
解释:返回date(0 = 周一, 1 = 周二, ... 6 = 周日)对应的工作日索引。即:date对应的范围是0至6。
注:DAYOFWEEK(date)和WEEKDAY(date)的功能相同,唯一的区别在于date对应的取值范围。
3、 YEAR、QUARTER、MONTH
- 求年份:
YEAR(date)
解释:返回date对应的年份,范围是从1000到9999。
- 求季度:
QUARTER(date)
解释:返回date对应的一年中的季度值,范围是从1到4。
- 求月份:(该月是一年当中的第几个月)
MONTH(date)
解释:返回date 对应的月份,范围是从1到12。
举例:


4、HOUR、MINUTE、SECOND
- 求小时:
HOUR(time)
解释:返回time 对应的小时数。对于日时值的返回值范围是从0到23 。
- 求分钟:
MINUTE(time)
解释:返回time对应的分钟数,范围是从0到59。
- 求秒数:
SECOND(time)
解释:返回time对应的秒数,范围是从0到59。
举例:



5、TO_DAYS、FROM_DAYS
- 求某日期,一共经历了多少天:(历史长河中)
TO_DAYS(date)
解释:给定一个日期date, 返回一个天数 (从年份0开始的天数 )。
- 求历史长河中的第某天,的日期:
FROM_DAYS(N)
解释:给定一个天数 N, 返回一个DATE值。
使用FROM_DAYS()处理古老日期时,务必谨慎,他不用于处理阳历出现前的天数(1582)。
6、CURDATE、CURTIME、NOW
- 求当前的年月日:
CURDATE()
解释:将当前日期按照'YYYY-MM-DD'或YYYYMMDD格式的值返回,具体格式根据函数用在字符串或是数字语境中而定。
举例:

- 求当前的时分秒:
CURTIME()
解释:将当前时间以'HH:MM:SS'或HHMMSS的格式返回,具体格式根据函数用在字符串或是数字语境中而定。
举例:

- 求当前的年月日、时分秒:
NOW()
举例:

注:如果now是放在语句当中,要看具体字段的格式要求。比如说,如果是放在date字段中,则只显示年月日;如果是放在datetime字段中,则同时显示年月日和时分秒。
MySQL字符串函数、日期时间函数的更多相关文章
- SQL server 创建 修改表格 及表格基本增删改查 及 高级查询 及 (数学、字符串、日期时间)函数[转]
SQL server 创建 修改表格 及表格基本增删改查 及 高级查询 及 (数学.字符串.日期时间)函数 --创建表格 create table aa ( UserName varchar(50 ...
- MySQL基础之 日期时间函数
基础日期函数和时间函数 1.CURDATE()函数:返回当前只带有年月日格式的日期 2.CURTIME()函数:返回当前只带有时分秒格式的时间 3.NOW()函数:返回当前日期和时间 4.UNIX_T ...
- ORACLE 常用函数 日期/时间函数
---------------------------------------------日期/时间函数----------------------------------------------- ...
- MYSQL 中常用日期时间函数使用
MySQL Date 函数 下面的表格列出了 MySQL 中最重要的内建日期函数: 函数 描述 NOW() 返回当前的日期和时间 CURDATE() 返回当前的日期 CURTIME() 返回当前的时间 ...
- MySQL最常用日期时间函数
日期和时间函数 可能的需求: 当前时间是多少.下个月的今天是星期几.统计截止到当前日期前 3 天的收入总和-- 上述需求就需要使用日期和时间函数来实现: MySQL服务器中的三种时区设置: ①系统时区 ...
- mysql与oracle的日期/时间函数小结
前言 本文的日期/时间全部格式化为”2016-01-01 01:01:01“形式: MONITOR_TIME为数据库表字段: 字符串与日期/时间相互转换函数 Oracle 日期/时间转字符串函数:to ...
- MYSQL 常用函数(数学、字符串、日期时间、系统信息、加密)
一.数学函数 数学函数主要用于处理数字,包括整型.浮点数等. ABS(x) 返回x的绝对值 SELECT ABS(-1) -- 返回1 CEIL(x),CEILING(x) 返回大于或等于x的最小整数 ...
- 【SQL】MySQL内置函数中的字符串函数和日期时间函数
字符串函数 --拼接字符串组成新的字符串 Select concat(‘A’,’B’); --返回字符串长度 Select length(“CAT”) --返回子字符串在字符串中首次出现的位置,没有返 ...
- MySQL数据库学习笔记(五)----MySQL字符串函数、日期时间函数
一.常见字符串函数: 1.CHAR_LENGTH 获取长度(字符为单位) 2.FORMAT 格式化 3.INSERT 替换的方式插入 4.INSTR 获取位置 5.LEFT/RIGHT 取左 ...
随机推荐
- 搭建Windows SVN服务器及TortoiseSVN使用帮助和下载
搭建Windows SVN服务器: 用的SVN服务器通常为外部,例如Google Code的服务器,不过,做为一个程序开发人员,就算自己一个人写程序,也应该有一个SVN版本控制系统,以便对开发代码进行 ...
- ean128与code128 条形码 算法分析
[code128条形码组成] 除终止符(STOP)由13个模块组成外,其他字符均由11个模块组成 就是说,如果用‘1’表示黑线(实模块),用‘0’表示白线(空模块),那么每表示一个字符就需要11条线, ...
- 操作3 mongodb和mysql 开启慢查询日志 ,以及mongodb从配置文件启动
1. mongodb从配置文件启动 创建配置文件:/usr/local/mongodb/etc/mongodb.conf 配置文件的内容为: #Directory and relavent set d ...
- <转载>使CSS文字图片div元素居中方法之水平居中的几个方法
文字居中,文字垂直居中水平居中,图片居中,图片水平居中垂直居中,块元素垂直居中?当我们在做前端开发是时候关于css居中的问题是很常见的.情 况有很多种,不同的情况又有不同的解决方式.水平居中的方式解决 ...
- EasyUI - Panel 面板控件
效果: html代码: <div id="p" style="padding: 10px;"> <p>panel content.< ...
- QDockWidget嵌套布局详解-实现Visual Studio布局
概述 许多工程软件,如Qt Creator,VS,matlab等,都是使用dock布局窗口,这样用户可以自定义界面,自由组合窗口. Qt的嵌套布局由QDockWidget完成,用Qt Creator拖 ...
- 基于visual Studio2013解决C语言竞赛题之1088模拟计算器
题目 解决代码及点评 /************************************************************************/ /* ...
- Eclipse 乱码问题 修改设置
1.工作空间的字符编码设置 2.对于任意的项目,可以右键选择属性,然后修改 3.对于任意一个文件,同样的操作,右键选择属性,然后配置字符编码
- Ubuntu_开启root 登陆
默认的安装完ubuntu ,root 用户没有开启 1.使用安装时的用户,先给root用户设置密码 设置root密码 sudo passwd root 之后会提示输入新的密码 切换到root用户 su ...
- App开发所要注意的几个法务问题(转)
GameLook 报道/ 移动应用市场的飞速发展催生出大量揭竿而起的开发者,同时许多矛盾也渐渐明显起来.其中涉及“抄袭”的问题尤为突出,毫不客气地说对于那些有底子的游戏厂商来说,法务已经成为团队中的一 ...