mysql存储过程及经常使用函数
一.函数
1.数学函数
CEIL()进一取整
SELECT CEIL(1.2);2
FLOOR()舍一取整
SELECT FLOOR(1.9);9
MOD取余数(取模)
SELECT MOD(3,8);3--3对8取模
POWER()幂运算
SELECT POWER(3,2);9
ROUND()四舍五入
SELECT ROUND(123.456,2);123.46
TRUNCTATE数字截取
SELECT TRUNCATE(123.456,2);123.45
ABS()取绝对值
SELECT ABS(-123);123
PI()圆周率
SELECT PI();3.14
RAND()和RAND(X)
SELECT RAND();0到1之间的一个随机数
SELECT RAND(2);0到1之间的一个随机数
ORDER BY RAND();按随机排序
SIGN(X)得到数值符合正数0和负数1
EXP(X)e的X方
2.字符串函数
LENGTH返回字符串长度
SELECT LENGTH('KAIKEBA');7
SELECT LENGTH('开课吧');6
CHAR_LENGTH返回字符串的字符数
SELECT CHAR_LENGTH('KAIKEBA');7
SELECT CHAR_LENGTH('开课吧');3
CONCAT(S1,S2,……)将字符串连接到一起
SELECT CONCAT('S','S','M');SSM
SELECT CONCAT('S',' ','M');SM
SELECT CONCAT('S','S',NULL);NULL字符串中有NULL。结果为NULL.
CONCAT_WS(S1,S2,……)以指定的分隔符将字符串连接到一起
SELECT CONCAT_WS('#','S','w','M');S#w#M
SELECTCONCAT_WS('#','S','w','M',NULL);S#w#M
SELECT CONCAT_WS(NULL,'S','w','M');NULL
UPPER(S)/UCASE(S)将字符串中的小写变大写
SELECTUPPER('RanDongmei'),UCASE('RanDongmei');RANDONGMEI RANDONGMEI
LOWER(s)/LCASE(S)将字符串中的大写变小写
LEFT(S,N)/RIGHT(S,N)返回字符串S前N个字符,后N个字符
SELECT LEFT('kaikeba',3);kai
SELECT RIGHT('天天向上。加油',2);油
LPAD|RPAD使用指定字符左填充或右填充至规定字符数
SELECT LPAD('KAI',5,'!');!!KAI
SELECT RPAD('KAI',5,'!');KAI!!
LTRIM|RTRIM|TRIM去掉字符串左边|右边|两边的空格
SELECT ' abc';
SELECT CONCAT('+',' AVC ','+');+ AVC +
SELECT CONCAT('+',LTRIM(' AVC '),'+');+AVC+
SELECT CONCAT('+',RTRIM(' AVC '),'+');+AVC+
SELECT CONCAT('+',TRIM(' AVC '),'+');+AVC+
仅仅有TRIM採有以下两种形式,LTRIM与RTRIM没有
SELECT TRIM('ABCBA'FROM 'A');A
SELECT TRIM('A'FROM 'ABCNA');BCN
SELECT TRIM('A'FROM 'ABCANA');BCAN
REPEAT(S,N)将字符串S反复N次
SELECT REPEAT('A',10);AAAAAAAAAA
SPACE(N)填充N个空格
SELECT SPACE(5);
SELECT CONCAT('+',SPACE(5),'+');+ +
REPLACE(S,S1,S2);将字符串S中的S1替换为S2
SELECTREPLACE('AAAASDDFO','A','R');RRRRSDDFO
STRCMP(S1,S2);比較字符串S1和S2,若相等返回0,若S1>S2返回1。若S1<S2返回-1.
SELECT STRCMP('A','A');0
SELECT STRCMP('A','B');-1
SELECT STRCMP('B','A');1第一个字符串大于第二个字符串
SELECT STRCMP('A','a');0不区分大写和小写
SUBSTRINT(S,a,b)从字符串的第a个字符取到第b个字符
SELECT SUBSTRING('KAIKEBA',1,3);KAI
从1開始,截取三个字符
SELECT SUBSTRING('KAIKEBA',-2,3);BA
SELECT SUBSTRING('KAIKEBA',-2,1);B
REVERSE(S);反转字符串S
SELECT REVERSE('ABCDE');EDCBA
ELT(N,S1,S2,S3,……);返回指定位置的字符串
SELECT ELT(3,'a','b','c','d');c
3.日期时间函数
返回当前日期
SELECT CURDATE();
SELECT CURRENT_DATE();
返回当前时间
SELECT CURTIME();
SELECT CURRENT_TIME();
返回当前日期时间
SELECT NOW();2014-11-07
SELECT SYSDATE();
返回月份
SELECT MONTH('2014-12-16');12
SELECT MONTHNAME(NOW());NOVEMBER
返回星期几
SELECT DAYNAME(NOW());Friday
一周的第几天,1:星期日
SELECT DAYOFWEEK(NOW());6
返回日期是星期几。0代表星期一
SELECT WEEKDAY(NOW());4
SELECT WEEK(NOW());44一年中的第44个星期
SELECT YEAR(NOW());2014
SELECT HOUR(NOW());
SELECT MINUTE(NOW());
SELECT SECOND(NOW());
计算两个日期间相隔天数
SELECTDATEDIFF('1988-12-16','2014-11-07');-9457天
SELECTDATEDIFF('1964-04-16','2014-11-07');-18467天
4.系统函数
SELECT VERSION();当前数据库版本
SELECT CONNECTION_ID();当前server的连接数
当前数据库:
SELECT DATABASE();
SELECT SCHEMA();
当前用户
SELECT USER();
SELECT SYSTEM_USER();
SELECT CURRENT_USER();
SELECT CURRENT_USER;
返回字符串STR的字符集
SELECT CHARSET('AFA');
SELECT LAST_INSERT_ID();最后一条插入记录ID号
5.加密函数
MD5()
PASSWORD();
SELECT MD5('ROOT');
SELECT PASSWORD('ROOT');
PASSWORD针对用户password加密
SELECT * FROM user WHERE User='root'\G;
加入权限时须要加入PASSWORDpassword
6.流程函数
IF
SELECT IF(3>1,'A','B');
SELECT id,username,IF(age>18,'成年','未成年') FROM employee;
SELECT IFNULL(NULL,'THIS IS NULL');THIS ISNULL
SELECT IFNULL(1,'THIS IS NULL');1,仅仅有为空时,才干变成后面这个值
二.存储过程
将SQL语句放在集合里,然后调用存储过程和函数来运行已经定义好的这些SQL语句。存储过程和函数能够避免程序开发者反复编写同样的SQL语句存储过程和函数保存在mysqlserver中的一个存储和运行。能够降低client和server端传输数据的消耗。
将一组SQL语句组合在一起,而且将这些SQL语句当作一个总体,存储在mysqlserver中。
存储过程就是:存储在mysqlserver的一组当作一个总体运行的SQL语句集合。
存储过程运行于server端。运行速度比較快,并且存储过程运行一次,它的运行规范驻留在快速缓冲存储器中,在以后的操作中仅仅须要从快速缓冲存储器调用已编译好的二进制代码,能够避免程序开发者反复编写同样的SQL语句、降低client和server端传输数据的消耗、提高系统性能和系统响应时间。也能够确保存储过程安全。由于我们使用存储过程能够完毕数据库的全部操作,也能够通过编程的方式来控制对数据库操作的訪问权限。
CREATE PROCEDURE
sp_name
([proc_parameter[...]])
[characteristic...]
routine_body
參数:三部分:
(1)输入输出的參数IN OUT INOUT
(2)名称
(3)类型
特性:
LANGUAGE SQL:运行体由SQL组成
DETERMINISTIC运行结果确定:同样输入得到同样输出
NOT DETERMINISTIC运行结果不确定
子程序使用SQL的一个限制:
CONTAINS SQL:子程序包括sql语句(默认)
NO SQL:子程序中不包括sql语句
READS SQL DATA子程序中包括查询数据语句
MODIFIES SQL DATA子程序中包括写数据语句
谁有权限运行存储过程
SQL SECURITY DEFINER|INVOKER
DEFINER:定义者(默认)
INVOKER:调用者
凝视
COMMENT 'string'
1>创建存储过程
改变分解符
DELIMITER //
CREATE PROCEDURE sp_demo()
BEGIN
SELECT * FROM user;
END
//
DELIMITER ;
DELIMITER //
CREATE PROCEDURE age_from_user(IN user_idINT,OUT user_age INT)
READS SQL DATA
BEGIN
SELECT age FROM user WHERE id=user_id;
END
//
DELIMITER ;
2>创建存储函数
CREATE FUNCTION sp_name
[func_parameter[..]]
RETURNS type
DELIMITER //
CREATE FUNCTION username_from_user(user_idINT)
RETURNS VARCHAR(20)
BEGIN
RETURN (SELECT username FROM user WHERE id=user_id);
END
//
DELIMITER ;
3>调用存储过程和函数
CALL sp_name([paramer..])
调用时必须有权限
CALL sp_demo();
CALL age_from_user(1,@user_age);
CALL age_from_user(2,@user_age);
调用存储函数
SELECT username_from_user(3);
4>查看创建好的存储过程和函数
SHOW PROCEDURE STATUS LIKE 'sp_demo'\G;
SHOW FUNCTION STATUS LIKE'username_from_user'\G;
详细存储过程与函数的定义
SHOW CREATE PROCEDURE sp_demo\G;
SHOW CREATE FUNCTION username_from_user\G;
创建的存储过程与函数存在information_schema数据库以下的ROUTINES表中
USE information_schema;
SELECT * FROM ROUTINES\G;
5>改动存储过程与函数
ALTER PROCEDURE|FUNCTION
ALTER PROCEDURE sp_demo COMMENT 'THIS IS ATEST PROCEDURE';
SHOW CREATE PROCEDURE sp_demo\G;
ALTER FUNCTION username_from_user COMMENT'THIS IS A TEST FUNCTION';
SHOW CREATE FUNCTION username_from_user\G;
6>删除存储过程与函数
DROP PROCEDURE sp_demo;
DROP PROCEDURE IF EXISTS sp_demo;
SHOW WARNINGS;
DROP FUNCTION username_from_user;
存储过程执行于server端,执行速度比較快。并且存储过程执行一次,它的执行规范驻留在快速缓冲存储器中,在以后的
操作中仅仅须要从快速缓冲存储器调用已编译好的二进制代码,提高系统性能和系统响应时间。也能够确保存储过程安全,由于我们使用存储过程能够完毕数据库的全部操作。也能够通过编程的方式来控制对数据库操作的訪问权限。
mysql存储过程及经常使用函数的更多相关文章
- mysql存储过程和存储函数
mysql存储过程和存储函数 存数函数代码示例: DROP PROCEDURE IF EXISTS calc_ci_day_suc_rate; delimiter // CREATE FUNCTION ...
- 基本开题的感觉是了-MySQL继续继续(自定义函数&存储过程)
hi 感觉论文开题基本确定了,凯森 1.MySQL -----自定义函数----- ----基本 两个必要条件:参数和返回值(两者没有必然联系,参数不一定有,返回一定有) 函数体:合法的SQL语句:以 ...
- mysql 存储过程和存储函数
14.1.1 创建存储过程 MySQL中,创建存储过程的基本形式如下: CREATE PROCEDURE sp_name ([proc_parameter[,...]]) [characteristi ...
- Mysql 存储过程和函数区别
存储过程是procedure用户定义的一系列sql语句的集合,涉及特定表或其它对象的任务,用户可以调用存储过程,而函数通常是数据库已定义的方法,它接收参数并返回某种类型的值并且不涉及特定用户表. 存储 ...
- MYSQL存储过程和函数学习笔记
学至Tarena金牌讲师,金色晨曦科技公司技术总监沙利穆课程笔记的综合. 1. 什么是存储过程和函数 将SQL语句放入一个集合里,然后直接调用存储过程和函数来执行已经定义好的SQL语句,通过存储过程和 ...
- Paip.断点调试MYSQL存储过程跟函数的解决方案大法
Paip.断点调试MYSQL存储过程跟函数的解决方案大法 作者Attilax , EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn ...
- mysql存储过程及常用函数
原文:mysql存储过程及常用函数 一.函数 1.数学函数 CEIL()进一取整 SELECT CEIL(1.2);2 FLOOR()舍一取整 SELECT FLOOR(1.9);9 MOD取余数(取 ...
- Mysql存储过程和函数
Mysql存储过程和函数 基本概念: 创建存储过程和函数是指将经常使用的一组SQL语句的组合在一起,并将这些SQL语句当作一个整体存储在MySQL服务器中.例如,银行经常需要计算用户的利息.不同类别的 ...
- MariaDB/MySQL存储过程和函数
本文目录:1.创建存储过程.函数 1.1 存储过程的IN.OUT和INOUT2.修改和删除存储过程.函数3.查看存储过程.函数信息 在MySQL/MariaDB中,存储过程(stored proced ...
随机推荐
- CoinChange
题目 题目:CoinChange 有面额不等的coins,数量无限,要求以最少的\(coins\)凑齐所需要的\(amount\). 若能,返回所需的最少coins的数量,若不能,返回-1. Exam ...
- Hibernate + Spring (quartz) 整合懒(延迟)加载问题
开发项目的时候 在一个Job中执行了数据库操作, 用的是懒加载,但是如下错误 org.hibernate.LazyInitializationException: failed to lazily i ...
- Centos6.5快速配置可用网卡
原文链接: Centos6.5快速配置可用网卡 安装完成后,我们启动我们的系统,此时我们的系统,是没有连网的,IP设备,并没有被激活,如果我们使用ifconfig命令查看IP地址,就会发现,此刻的地址 ...
- parquet 合并元数据
合并元数据:两个数据集,有着一部分相同的列,将他们合并成一个数据集时merge的过程. 合并的规则:相同的列,在新的数据集中,是通用的列, 各自不同的列,也作为新的数据集的列. Spark将数据写入到 ...
- Http方式获取网络数据
通过以下代码可以根据网址获取网页的html数据,安卓中获取网络数据的时候会用到,而且会用Java中的sax方式解析获取到数据.(sax解析主要是解析xml)具体代码如下: package com.wy ...
- iOS开发之自己封装一个progressHUD控件
看了几个轻量级的progress view 我觉得KVNProgress做的最漂亮吧 突然我想为什么我自己不封装一个控件 然后我研究了一下KVNProgress KVN简单的界面是由storyboar ...
- 读取sd卡下图片,由图片路径转换为bitmap
public Bitmap convertToBitmap(String path, int w, int h) { BitmapFactory.Options opts = ...
- [置顶] 小白学习KM算法详细总结--附上模板题hdu2255
KM算法是基于匈牙利算法求最大或最小权值的完备匹配 关于KM不知道看了多久,每次都不能完全理解,今天花了很久的时间做个总结,归纳以及结合别人的总结给出自己的理解,希望自己以后来看能一目了然,也希望对刚 ...
- USACO 2005 January Gold The Wedding Juicer
题目 题目链接,我只在poj上找到了题目,usaco居然上不去. 大意就是说有一些\(1\times 1\times 1\)的小方块堆在一起,问最多能装多少水. 我们在一次测试中出了这题,由于我写水题 ...
- HDU 3790 最短路径问题 (SPFA)
转载请注明出处:http://blog.csdn.net/a1dark 分析:比一般最短路多了一个花费.多加一个判断即可.用的SPFA.这道题让我搞清楚了以前定义INF为啥爆的问题.受益颇多. #in ...