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();当前服务器的连接数
当前数据库:
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针对用户密码加密
SELECT * FROM user WHERE User='root'\G;
添加权限时需要添加PASSWORD密码
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语句存储过程和函数保存在mysql服务器中的一个存储和执行,可以减少客户端和服务器端数据传输的消耗。
将一组SQL语句组合在一起,并且将这些SQL语句当作一个整体,存储在mysql服务器中。
存储过程就是:存储在mysql服务器的一组当作一个整体执行的SQL语句集合。存储过程运行于服务器端,运行速度比较快,而且存储过程执行一次,它的执行规范驻留在高速缓冲存储器中,在以后的操作中只需要从高速缓冲存储器调用已编译好的二进制代码,可以避免程序开发人员重复编写相同的SQL语句、减少客户端和服务器端数据传输的消耗、提高系统性能和系统响应时间,也可以确保存储过程安全,因为我们使用存储过程可以完成数据库的所有操作,也可以通过编程的方式来控制对数据库操作的访问权限。
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;
存储过程运行于服务器端,运行速度比较快,而且存储过程执行一次,它的执行规范驻留在高速缓冲存储器中,在以后的
操作中只需要从高速缓冲存储器调用已编译好的二进制代码,提高系统性能和系统响应时间。也可以确保存储过程安全,因为我们使用存储过程可以完成数据库的所有操作,也可以通过编程的方式来控制对数据库操作的访问权限。
mysql存储过程及常用函数的更多相关文章
- mysql存储过程和存储函数
mysql存储过程和存储函数 存数函数代码示例: DROP PROCEDURE IF EXISTS calc_ci_day_suc_rate; delimiter // CREATE FUNCTION ...
- Mysql中的常用函数:
Mysql中的常用函数: 1.字符串函数: (1).合并字符串 concat():// concat('M','y',"SQL",'5.5');== MySQL5.5//当传入的参 ...
- mysql 存储过程和存储函数
14.1.1 创建存储过程 MySQL中,创建存储过程的基本形式如下: CREATE PROCEDURE sp_name ([proc_parameter[,...]]) [characteristi ...
- MySQL学习总结(四)数据的基本操作以及MySQL运算符和常用函数
数据库是存储数据库对象的仓库,数据库的基本对象是表,表用来存储数据.关于数据的操作也就是我们常说的CRUD,C指的是CREATE(插入数据记录).R指的是READ(查询数据记录).U指的是UPDATE ...
- SqlServer存储过程中常用函数及操作
1.case语句 用于选择语句 SELECT ProductNumber, Category = CASE ProductLine WHEN 'R' THEN 'Road' WHEN 'M' THEN ...
- MySQL存储过程和自定义函数、Navicat for mysql、创建存储过程和函数、调用存储过程和函数的区别
1 MySQL存储过程和函数 过程和函数,它们被编译后保存在数据库中,称为持久性存储模块(Persistent Stored Module,PSM),可以反复调用,运行速度快. 1.1 存储过程 存储 ...
- MySQL基础之常用函数
数学函数的使用 常用数学函数 函数 作用 函数 作用 ceil() 进一取整 abs() 取绝对值 floor() 舍掉小数部分 power() 幂运算 round() 四舍五入 pi() 圆周率 t ...
- Mysql命令、常用函数
一.sql命令行 查看数据库 show database : 选择使用的数据库 use 数据库名 : 查看表 show tables ; 查询表 select * from 表名 高版本my ...
- MySQL注入时常用函数
注入常用函数 数据库相关 database() --- 返回当前数据库名 @@datadir --- 读取数据库路径 @@basedir --- 读取数据库安全路径 @@version_compile ...
随机推荐
- Notification使用以及PendingIntent.getActivity() (转)
public void sendNotification(Context ctx,String message) { //get the notification manager String ns ...
- 基于ORACLE建表和循环回路来创建数据库存储过程SQL语句来实现
一个.概要 在实际的软件开发项目.我们经常会遇到需要创造更多的相同类型的数据库表或存储过程时,.例如.假设按照尾号点表的ID号,然后,你需要创建10用户信息表,的用户信息放在同一个表中. 对于类型同样 ...
- poj2443(简单的状态压缩)
POJ2443 Set Operation Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 2679 Accepted: ...
- C语言学习_查找三分之二
查找三分之二: #include <stdio.h> #define M 10 int main(void) { int front, near, mid1, mid2; int n; i ...
- VS2010-使用“预先生成事件命令行”和“后期生成事件命令行”功能
原文:VS2010-使用"预先生成事件命令行"和"后期生成事件命令行"功能 xcopy /r /y $(TargetPath) $(ProjectDir)..\ ...
- Linux_修改创建文件夹时默认权限(修改为能上传)
1:查看当前权限 umask 0022 意思就是权限为:777-022 =755 读 2:临时修改 umask 020 020 意思为:777-020=757 读写上传 3:永久修改 回到根目录 cd ...
- JVMTI 中间JNI系列功能,线程安全和故障排除技巧
JVMTI 中间JNI系列功能,线程安全和故障排除技巧 jni functions 在使用 JVMTI 的过程中,有一大系列的函数是在 JVMTI 的文档中 没有提及的,但在实际使用却是很实用的. 这 ...
- 【LeetCode】 sort list 单清单归并
称号:Sort a linked list in O(n log n) time using constant space complexity. 思路:要求时间复杂度O(nlogn) 知识点:归并排 ...
- JAVA简单Swing图形界面应用演示样例
JAVA简单Swing图形界面应用演示样例 package org.rui.hello; import javax.swing.JFrame; /** * 简单的swing窗体 * @author l ...
- Linux中加入用户、删除用户时新手可能遇到的问题
Linux中加入用户.删除用户时新手可能遇到的问题 1.创建新用户后切换到新用户:No directory, logging in with HOME=/ 加入用户 #sudo us ...