博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql 函数 事务
阅读量:6547 次
发布时间:2019-06-24

本文共 5483 字,大约阅读时间需要 18 分钟。

mysql 中提供了许多内置函数

CHAR_LENGTH(str)        返回值为字符串str 的长度,长度的单位为字符。一个多字节字符算作一个单字符。        对于一个包含五个二字节字符集, LENGTH()返回值为 10, 而CHAR_LENGTH()的返回值为5。    CONCAT(str1,str2,...)        字符串拼接        如有任何一个参数为NULL ,则返回值为 NULL。    CONCAT_WS(separator,str1,str2,...)        字符串拼接(自定义连接符)        CONCAT_WS()不会忽略任何空字符串。 (然而会忽略所有的 NULL)。    CONV(N,from_base,to_base)        进制转换        例如:            SELECT CONV('a',16,2); 表示将 a 由16进制转换为2进制字符串表示    FORMAT(X,D)        将数字X 的格式写为'#,###,###.##',以四舍五入的方式保留小数点后 D 位, 并将结果以字符串的形式返回。若  D 为 0, 则返回结果不带有小数点,或不含小数部分。        例如:            SELECT FORMAT(12332.1,4); 结果为: '12,332.1000'    INSERT(str,pos,len,newstr)        在str的指定位置插入字符串            pos:要替换位置其实位置            len:替换的长度            newstr:新字符串        特别的:            如果pos超过原字符串长度,则返回原字符串            如果len超过原字符串长度,则由新字符串完全替换    INSTR(str,substr)        返回字符串 str 中子字符串的第一个出现位置。    LEFT(str,len)        返回字符串str 从开始的len位置的子序列字符。    LOWER(str)        变小写    UPPER(str)        变大写    LTRIM(str)        返回字符串 str ,其引导空格字符被删除。    RTRIM(str)        返回字符串 str ,结尾空格字符被删去。    SUBSTRING(str,pos,len)        获取字符串子序列    LOCATE(substr,str,pos)        获取子序列索引位置    REPEAT(str,count)        返回一个由重复的字符串str 组成的字符串,字符串str的数目等于count 。        若 count <= 0,则返回一个空字符串。        若str 或 count 为 NULL,则返回 NULL 。    REPLACE(str,from_str,to_str)        返回字符串str 以及所有被字符串to_str替代的字符串from_str 。    REVERSE(str)        返回字符串 str ,顺序和字符顺序相反。    RIGHT(str,len)        从字符串str 开始,返回从后边开始len个字符组成的子序列    SPACE(N)        返回一个由N空格组成的字符串。    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 使用一个负值。        mysql> SELECT SUBSTRING('Quadratically',5);            -> 'ratically'        mysql> SELECT SUBSTRING('foobarbar' FROM 4);            -> 'barbar'        mysql> SELECT SUBSTRING('Quadratically',5,6);            -> 'ratica'        mysql> SELECT SUBSTRING('Sakila', -3);            -> 'ila'        mysql> SELECT SUBSTRING('Sakila', -5, 3);            -> 'aki'        mysql> SELECT SUBSTRING('Sakila' FROM -4 FOR 2);            -> 'ki'    TRIM([{BOTH | LEADING | TRAILING} [remstr] FROM] str) TRIM(remstr FROM] str)        返回字符串 str , 其中所有remstr 前缀和/或后缀都已被删除。若分类符BOTH、LEADIN或TRAILING中没有一个是给定的,则假设为BOTH 。 remstr 为可选项,在未指定情况下,可删除空格。        mysql> SELECT TRIM('  bar   ');                -> 'bar'        mysql> SELECT TRIM(LEADING 'x' FROM 'xxxbarxxx');                -> 'barxxx'        mysql> SELECT TRIM(BOTH 'x' FROM 'xxxbarxxx');                -> 'bar'        mysql> SELECT TRIM(TRAILING 'xyz' FROM 'barxxyz');                -> 'barx'部分内置函数
你猜猜
select date_format('2009-10-01 22:30:10','%W %M %Y')# Thursday October 2009select date_format('2014-10-10 22:24:10','%H:%i:%s')# 22:24:10select date_format('1996-12-20 22:24:10','%D %y %a %d %m %b %j')# 20th 96 Fri 20 12 Dec 355select date_format('1996-12-20', '%x %v')# 1996 51select date_format('2006-06-00','%d')# 00# 准备表和记录create table blog(    id int primary key  auto_increment,    name char(32),    sub_time datetime)insert into blog(name,sub_time)VALUES    ('第1篇','2015-03-01 11:31:21'),    ('第2篇','2015-03-11 16:31:21'),    ('第3篇','2016-07-01 10:21:31'),    ('第4篇','2016-07-22 09:23:21'),    ('第5篇','2016-07-23 10:11:11'),    ('第6篇','2016-07-25 11:21:31'),    ('第7篇','2017-03-01 15:33:21'),    ('第8篇','2017-03-01 17:32:21'),    ('第9篇','2017-03-01 18:31:21');select date_format(sub_time,'%Y-%m'),count(1) from blog GROUP BYdate_format(sub_time,'%Y-%m')# 2015-03    2# 2016-07    4# 2017-03    3
需掌握
# 截取字符串select substring('zxcvbnm',5)# bnmselect substring('zxcvbnm',-5,3)# cvb# 返回的是字符类型个数select char_length('中文')# 2# 返回的是字节个数select length('中文')# 6# 拼接select concat('alex','zxcv','啦啦啦')# alexzxcv啦啦啦select concat('alex','zxcv','啦啦啦',null)#null  拼接了null 则返回null# 格式化# 保留小数点select format (132562.258,4)# 132,562.2580

 

一、自定义函数

#!!!注意!!!#函数中不要写sql语句(否则会报错),函数仅仅只是一个功能,是一个在sql中被应用的功能#若要想在begin...end...中写sql,请用存储过程
# 自定义函数create FUNCTION fun1(i int ,x int)    returns int begin     DECLARE sum int DEFAULT 0;    set sum = i+x;    return (sum);ENDselect fun1(100,50)

二、删除函数

drop function func_name;
View Code

三、执行函数

# 获取返回值select UPPER('egon') into @res;SELECT @res;# 在查询中使用select f1(11,nid) ,name from tb2;
View Code

 

事务

事务用于将某些操作的多个SQL作为原子性操作,一旦有某一个出现错误,即可回滚到原来的状态,从而保证数据库数据完整性。

create table user (    id int primary key auto_increment,    name char(32),    balance int )insert into user (name,balance) values('wsb',1000),('egon',1000),('ysb','1000')# 原子操作start transaction #开启事务update user set balance = 900 where name  = 'wsb'update user set balance = 1010 where name = 'egon'update user set balance = 1090 where name = 'ysb'commit # 提交事务# 出现异常,回滚到初始状态start transaction update user set balance = 900 where name = 'wsb'update user set balance = 1010 where name = 'egon'uppdate user set balance = 1090 where name = 'ysb'ROLLBACK   # 回滚commit
View Code

 

事务的特性: 事务有以下四个标准属性的缩写ACID,通常被称为:
原子性: 确保工作单元内的所有操作都成功完成,否则事务将被中止在故障点,和以前的操作将回滚到以前的状态。
一致性: 确保数据库正确地改变状态后,成功提交的事务。
隔离性: 使事务操作彼此独立的和透明的。
持久性: 确保提交的事务的结果或效果的系统出现故障的情况下仍然存在。

事务的开启:start transaction;
commit & rollback:这两个关键字提交和回滚主要用于MySQL的事务。

当一个成功的事务完成后,发出COMMIT命令应使所有参与表的更改才会生效。

如果发生故障时,应发出一个ROLLBACK命令返回的事务中引用的每一个表到以前的状态。

 

 

# 1、用了事务,就不可避免的要牺牲一部分速度,来保证数据的正确性。只有InnoDB支持事务# 事务 ACID Atomicity(原子性)、Consistency(稳定性)、Isolation(隔离性)、Durability(可靠性)

 

转载于:https://www.cnblogs.com/jassin-du/p/8033390.html

你可能感兴趣的文章
php进一法取整、四舍五入取整、忽略小数等的取整数方法大全
查看>>
WSDP
查看>>
Memory Management
查看>>
JQUERY 对 表格中的数据重排序
查看>>
程序员常用借口指南
查看>>
awk 常用方法
查看>>
Android网络框架实现之【Retrofit+RxJava】
查看>>
Android文件的加密与解密
查看>>
【原】记录一句话
查看>>
Android标题栏,状态栏
查看>>
java笔记:SpringSecurity应用(二)
查看>>
php记录代码执行时间
查看>>
简简单单几段代码让自己变成最合格的网站管理员
查看>>
[置顶] 遵循Java EE标准体系的开源GIS服务平台之二:平台部署
查看>>
Java递归算法——阶乘
查看>>
Multi-voltage和power gating的实现
查看>>
JavaScript面向对象 ~ 原型和继承(1)
查看>>
spring cloud微服务分布式云架构--hystrix的使用
查看>>
解决Mac启动Eclipse Memory Analyzer报错问题
查看>>
自己写的进度条###
查看>>