【数据库】MySql深入

转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/5866388.html

MySql常用函数梳理:

1:数学函数

使用格式:一般用于插入、修改语句中,直接 函数(参数) 即可,把返回结果用于插入、修改。

RAND():随机数生成。

ROUND(X,Y):得到X的Y位四舍五入小数。

LOG(x,y):得到以x为底,y的对数。

SQRT(x):得到x的平方根。

应用实例:

insert into test values (RAND(0),ROUND(4.5462,3),LOG(2,8),SQRT(9));
select * from test;

结果:

0,4.54600000000000000000000000000,3.0000000000000000000000000000000,3.0000000000000000000000000000000

2:聚集函数

使用格式:聚集函数一般是配合GROUP BY语句使用的,也可以用于统计整表、整列。

SQL聚集函数
函数 说明
AVG() 返回某列的平均值
COUNT() 返回某列/某组/整表的行数(即记录数)
MAX() 返回某列的最大值
MIN() 返回某列的最小值
SUM() 返回某个列之和

样例:

select COUNT(*)  from test GROUP BY id;

select AVG(grade) from student;

select MAX(grade) from student;

select MIN(grade) from student;

select SUM(grade) from student;

3:字符串函数

字符串函数的使用格式:select 函数(参数) from 表;

CONCAT(str1,str2,...) :返回结果为连接参数产生的字符串。如有任何一个参数为NULL ,则返回值为 NULL。

ASCII(str):返回字符串str 的最左字符的数值。假如str为空字符串,则返回值为 0 。假如str 为NULL,则返回值为 NULL。 ASCII()用于带有从 0到255的数值的字符。

BIN(N):返回N的二进制值的字符串。

CHAR_LENGTH(str):返回值为字符串str 的长度,长度的单位为字符。

CONV(str,from_base,to_base):不同进制的转换。返回str字符串由from_base进制转化为 to_base 进制的数字串表示。

ELT(N,str1,str2,str3,...):返回第一个参数后面的第N个参数。返回若N = 1,则返回值为  str1 ,若N = 2,则返回值为 str2 ,以此类推。

FIELD(str,str1,str2,str3,...):返回str1, str2, str3,……列表中的str 的个数。在找不到str 的情况下,返回值为 0 。

FIND_IN_SET(str,strlist):假如字符串str 在字符串列表strlist 中, 则返回其在列表中的位置。一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串。

FORMAT(X,D):将number X设置为格式 ‘#,###,###.##‘, 以四舍五入的方式保留到小数点后D位, 而返回结果为一个字符串。

INSERT(str,pos,len,newstr):字符串 str的pos到len长的位置被newstr替换。

INSTR(str,substr):返回字符串 str 中子字符串substr的第一个出现位置。

POSITION(substr IN str):返回子串substr在字符串str第一个出现的位置,如果substr不是在str里面,返回0。

LOCATE(substr,str,pos)返回子串substr在字符串str第一个出现的位置,从位置pos开始。如果substr不是在str里面,返回0。

LEFT(str,len):返回字符串str 从左起len长的子串。

RIGHT(str,len):从字符串str 开始,返回最右len 字符。

LENGTH(str):返回值为字符串str 的长度,单位为字节。

LOWER(str):把str全部变为小写。

REPEAT(str,count):str重复count次而成的新字符串。

REPLACE(str,from_str,to_str):把str中的from_str内容替换为to_str.

REVERSE(str):把str倒序。

RPAD(str,len,padstr):把str用padstr填充到len长。

SUBSTRING(str,pos) , SUBSTRING(str FROM pos):字符串str返回一个子字符串,起始于位置 pos。

SUBSTRING(str,pos,len) , SUBSTRING(str FROM pos FOR len):字符串str返回一个长度同len字符相同的子字符串,起始于位置 pos。

TRIM([{BOTH | LEADING | TRAILING} [remstr] FROM] str) ,TRIM(remstr FROM str):从str中删除remstr。

UPPER(str):把str转为大写。

4:日期和时间函数

NOW():返回该条语句【注意,是该条语句,而不是该函数。区别在于下面的sysdate()函数】运行时的具体日期时间。

eg:select NOW();

re:2016-09-12 21:25:06

sysdate(): 日期时间函数跟 now() 类似,不同之处在于:now() 在语句执行开始时值就得到了, sysdate() 在函数执行时动态得到值。

mysql> select now(), sleep(3), now();

+---------------------+----------+---------------------+
| now()               | sleep(3) | now()               |
+---------------------+----------+---------------------+
| 2008-08-08 22:28:21 |        0 | 2008-08-08 22:28:21 |
+---------------------+----------+---------------------+

mysql> select sysdate(), sleep(3), sysdate();

+---------------------+----------+---------------------+
| sysdate()           | sleep(3) | sysdate()           |
+---------------------+----------+---------------------+
| 2008-08-08 22:28:41 |        0 | 2008-08-08 22:28:44 |
+---------------------+----------+---------------------+

可以看到,虽然中途 sleep 3 秒,但 now() 函数两次的时间值是相同的; sysdate() 函数两次得到的时间值相差 3 秒。

curdate():获取当前日期。

curtime():获得当前时间(time)函数。

时间选取函数:

选取日期时间的各个部分:日期、时间、年、季度、月、日、小时、分钟、秒、微秒

set @dt = ‘2008-09-10 07:15:30.123456‘;

select date(@dt);        -- 2008-09-10
select time(@dt);        -- 07:15:30.123456
select year(@dt);        -- 2008
select quarter(@dt);     -- 3
select month(@dt);       -- 9
select week(@dt);        -- 36
select day(@dt);         -- 10
select hour(@dt);        -- 7
select minute(@dt);      -- 15
select second(@dt);      -- 30
select microsecond(@dt); -- 123456

dayname(), monthname(): 返回星期和月份名称。
select dayname(@dt);     -- Friday
select monthname(@dt);   -- August:

WEEKDAY(date) :返回date的星期索引(0=星期一,1=星期二, ……6= 星期天)。

DAYOFMONTH(date) :返回date的月份中日期,在1到31范围内。

DAYOFYEAR(date) :返回date在一年中的日数, 在1到366范围内。

MONTH(date) :返回date的月份,范围1到12。

DAYNAME(date) :返回date的星期名字,比如:Friday。

MONTHNAME(date) :返回date的月份名字。

QUARTER(date) :返回date一年中的季度,范围1到4。

 

5:加密解密函数

ENCODE(,)   DECODE(,):加密解密字符串。该函数有两个参数:被加密或解密的字符串和作为加密或解密基础的密钥。Encode结果是一个二进制字符串,以BLOB类型存储。

加密 INSERT INTO users (username, password) VALUES (‘joe‘, ENCODE(‘guessme‘, ‘abracadabra‘));

解密 SELECT DECODE(password, ‘abracadabra‘) FROM users WHERE username=‘joe‘;

MD5():计算字符串的MD5校验和(128位)。

SHA5():计算字符串的SHA5校验和(160位)

6:格式化函数

FORMAT(x,y) :把x格式化以逗号分隔开的数字序列,y是结果的小数位数。同时,结果会以 , 每3位数进行分割,像金额表达一样。

DATE_FORMAT(date,fmt) 和TIME_FORMAT(time,fmt)函数可以用来格式化日期和时间值:这俩函数接受日期或者时间值和一个指定结果格式的格式化字符串。这个格式化字符串包含特殊的符号。不同的符号表示不同的内容,字符串就是一系列自选的符号组成,这样日期或时间就会按照字符串表示的格式表达出来。

说明符 说明
%a 工作日的缩写名称  (Sun..Sat)
%b 月份的缩写名称 (Jan..Dec)
%c 月份,数字形式(0..12)
%D 带有英语后缀的该月日期 (0th, 1st, 2nd, 3rd, …)
%d 该月日期, 数字形式 (00..31)
%e 该月日期, 数字形式(0..31)
%f 微秒 (000000..999999)
%H 小时(00..23)
%h 小时(01..12)
%I 小时 (01..12)
%i 分钟,数字形式 (00..59)
%j 一年中的天数 (001..366)
%k 小时 (0..23)
%l 小时 (1..12)
%M 月份名称 (January..December)
%m 月份, 数字形式 (00..12)
%p 上午(AM)或下午( PM)
%r 时间 , 12小时制 (小时hh:分钟mm:秒数ss 后加 AM或PM)
%S 秒 (00..59)
%s 秒 (00..59)
%T 时间 , 24小时制 (小时hh:分钟mm:秒数ss)
%U 周 (00..53), 其中周日为每周的第一天
%u 周 (00..53), 其中周一为每周的第一天
%V 周 (01..53), 其中周日为每周的第一天 ; 和 %X同时使用
%v 周 (01..53), 其中周一为每周的第一天 ; 和 %x同时使用
%W 工作日名称 (周日..周六)
%w 一周中的每日 (0=周日..6=周六)
%X 该周的年份,其中周日为每周的第一天, 数字形式,4位数;和%V同时使用
%x 该周的年份,其中周一为每周的第一天, 数字形式,4位数;和%v同时使用
%Y 年份, 数字形式,4位数
%y 年份, 数字形式 (2位数)
%% ‘%’文字字符
时间: 2024-10-25 11:28:16

【数据库】MySql深入的相关文章

MYSQL添加新用户 MYSQL为用户创建数据库 MYSQL为新用户分配权限

1.新建用户 //登录MYSQL@>mysql -u root -p@>密码//创建用户mysql> insert into mysql.user(Host,User,Password) values('localhost','jeecn',password('jeecn'));//刷新系统权限表mysql>flush privileges;这样就创建了一个名为:jeecn  密码为:jeecn  的用户. //退出后登录一下mysql>exit;@>mysql -u

趁一切还来得及【六】数据库MySQL读写分离与主主同步

相思相见知何日?此时此夜难为情.                                                      --[唐]李白 第一章 数据库MySQL主从复制读写分离授权 1.1 主从复制读写分离方案简单分析 ①数据库主从复制搭建之后,因为数据是单向的,因此默认规则就是所有的数据(主从相关收据)写入和更新都在主库上进行操作,避免主从同步的时候造成冲突. ②严格上来讲,从库上的非同步的库写入数据,只要和主库没有关系,也是可以写入的(或者作为主库),但是如果主从都想其中

第二百八十五节,MySQL数据库-MySQL函数

MySQL数据库-MySQL函数 1.MySQL内置函数 SELECT执行函数,后面跟要执行的函数 CHAR_LENGTH(str)函数:返回字符串的字符长度 -- CHAR_LENGTH(str)函数:返回字符串的字符长度 SELECT CHAR_LENGTH('欢迎光临'); LENGTH(str)函数:返回字符串的字节长度 -- LENGTH(str)函数:返回字符串的字节长度 SELECT LENGTH('欢迎光临'); CONCAT(str1,str2,...)函数:拼接字符串 --

Java处理数据库Mysql汉字显示乱码问题

问题:在unbuntu用eclipse编写程序的时候,发现存入数据库mysql的汉字都变成了??? 原因:eclipse和mysql的默认编码方式不一致 解决方法:把eclipse和mysql的编码方式都设置为utf8 1.设置mysql默认编码方式为utf8 修改mysql数据库的my.cnf文件,my.cnf文件路径为/etc/mysql/my.cnf 在[client]下面添加 default-character-set = utf8 在[mysqld]下面添加 character-set

Centos7下Gitlab迁移数据库mysql过程

第1章 系统准备 [[email protected] ~]# cat /etc/redhat-release CentOS Linux release 7.2.1511 (Core) [[email protected] ~]# uname -r 3.10.0-327.el7.x86_64 1.1添加阿里云的镜像 cd /etc/yum.repos.d #备份原镜像 mv CentOS-Base.repo CentOS-Base.repo.backup     #添加阿里云Base源 wget

paip.导入数据英文音标到数据库mysql为空的问题之道解决原理

#---原因:mysql 导入工具的bug #---解决:使用双引号不个音标括起来. 作者 老哇的爪子 Attilax 艾龙,  EMAIL:[email protected] 转载请注明来源: http://blog.csdn.net/attilax from log import * iniLog (r"c:\enWzPhonetic.log") n=0 for line in lines: if(n>100000 ):break; if( not isContain(lin

数据库---mysql主从复制读写分离

http://m.open-open.com/m/lib/view/1413274853450.html 原理及架构分析 部署前准备 下载好源码包存放位置要与脚本中对应 mysql-5.5.22.tar.gz,cmake-2.8.6.tar.gz,amoeba-mysql-binary-2.2.0.tar.gz,jdk-6u14-linux-x64.bin selinux和iptables不做设置,关闭 系统光盘镜像为本地yum源,配置好yum文件 环境介绍: 主服务器(master):192.

数据库mysql 分库备份脚本

数据库mysql 分库备份脚本 在企业工作中,我们经常会遇到数据库备份问题,当然我之前不止提到过mysql 主从,现在我们 先来看看单库如何来实现分库定期进行备份的,先看一下以下脚本: vi mysql_backup.sh #!/bin/sh #backup tiandao bbs edoing #coding tonye.li MYUSER=root MYPASS=meidi SOCKET=/data/3306/mysql.sock MYCMD="mysql -u$MYUSER -p$MYPA

数据库mysql 自动分库分表备份脚本

数据库mysql 自动分库分表备份脚本 当我们在公司中遇到数据库的备份,项目比较多,经常进行数据库和表的添加工作,那么我们 想要让系统脚本自动进行查询数据库里的库和表结构,然后进行自动的定期进行数据库和表的定期份, 那么我们该如何实现呢,大家看看以下的脚本: vi mysql_backup.sh #!/bin/sh #backup tiandao bbs edoing #coding tonye.li MYUSER=root MYPASS=meidi SOCKET=/data/3306/mysq

趁一切还来得及【一】数据库MySQL基础知识及编译安装

此情更待成追忆,只是当时已惘然.                                        --[唐]李商隐 第一章 数据库概述及分类特点应用 1.1 数据库种类.语言处理.典型产品 ①数据库的理解:就是一个存放数据的仓库,这个仓库是按照一定的数据结构,来组织和存储的.可以通过数据库提供的多种方法来管理数据库. ②数据库的种类:按照早期的数据库理论分为层次数据库.网络式数据库.和关系型数据库.当今互联网最常用的就是关系型数据库和非关系型数据库(NOSQL). ③关系型数据库: