mysql存储过程及常用函数

时间:2022-12-30 12:16:44

原文: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存储过程及常用函数的更多相关文章

  1. mysql存储过程和存储函数

    mysql存储过程和存储函数 存数函数代码示例: DROP PROCEDURE IF EXISTS calc_ci_day_suc_rate; delimiter // CREATE FUNCTION ...

  2. Mysql中的常用函数&colon;

    Mysql中的常用函数: 1.字符串函数: (1).合并字符串 concat():// concat('M','y',"SQL",'5.5');== MySQL5.5//当传入的参 ...

  3. mysql 存储过程和存储函数

    14.1.1 创建存储过程 MySQL中,创建存储过程的基本形式如下: CREATE PROCEDURE sp_name ([proc_parameter[,...]]) [characteristi ...

  4. MySQL学习总结(四)数据的基本操作以及MySQL运算符和常用函数

    数据库是存储数据库对象的仓库,数据库的基本对象是表,表用来存储数据.关于数据的操作也就是我们常说的CRUD,C指的是CREATE(插入数据记录).R指的是READ(查询数据记录).U指的是UPDATE ...

  5. SqlServer存储过程中常用函数及操作

    1.case语句 用于选择语句 SELECT ProductNumber, Category = CASE ProductLine WHEN 'R' THEN 'Road' WHEN 'M' THEN ...

  6. MySQL存储过程和自定义函数、Navicat for mysql、创建存储过程和函数、调用存储过程和函数的区别

    1 MySQL存储过程和函数 过程和函数,它们被编译后保存在数据库中,称为持久性存储模块(Persistent Stored Module,PSM),可以反复调用,运行速度快. 1.1 存储过程 存储 ...

  7. MySQL基础之常用函数

    数学函数的使用 常用数学函数 函数 作用 函数 作用 ceil() 进一取整 abs() 取绝对值 floor() 舍掉小数部分 power() 幂运算 round() 四舍五入 pi() 圆周率 t ...

  8. Mysql命令、常用函数

    一.sql命令行 查看数据库 show database : 选择使用的数据库 use 数据库名  : 查看表 show tables ; 查询表 select * from 表名     高版本my ...

  9. MySQL注入时常用函数

    注入常用函数 数据库相关 database() --- 返回当前数据库名 @@datadir --- 读取数据库路径 @@basedir --- 读取数据库安全路径 @@version_compile ...

随机推荐

  1. 解决&OpenCurlyDoubleQuote;Dynamic Web Module 3&period;0 requires Java 1&period;6 or newer&period;”错误

    一.问题描述 1.错误截图如下. 2.设计的问题 在Eclipse中新建了一个Maven工程, 然后更改JDK版本为1.6, 结果每次使用Maven > Update project的时候JDK ...

  2. JavaScript : 零基础打造自己的类库

    写作不易,转载请注明出处,谢谢. 文章类别:Javascript基础(面向初学者) 前言 在之前的章节中,我们已经不依赖jQuery,单纯地用JavaScript封装了很多方法,这个时候,你一定会想, ...

  3. event相关

    event.button 事件属性可返回一个整数,指示当事件被触发时哪个鼠标按键被点击. event.keyCode  事件属性可返回一个整数,指示当事件被触发时哪个键盘按键被点击. <scri ...

  4. &lbrack;另开新坑&rsqb; 算导v3 &num;26 最大流 翻译

    26 最大流 就像我们可以对一个路网构建一个有向图求最短路一样,我们也可以将一个有向图看成是一个"流量网络(flow network)",用它来回答关于流的问题. Just as ...

  5. Action开发、通配符、路径问题和struts中常量用法

    1.action开发 开发的几种方式 (1).继承自ActionSupport,(如果用struts的数据效验功,能必须必须使用此功能,因为ActionSupport实现了数据效验的接口) publi ...

  6. 关于textField

    如果想给textField设置背景图片,首先设置该控件的bounder Style为最左边的无style,然后设置背景图片   如果设置textField弹出键盘 的发送按钮:设置右侧Return K ...

  7. Python 标识符

    Python 标识符 在python里,标识符有字母.数字.下划线组成. 在python中,所有标识符可以包括英文.数字以及下划线(_),但不能以数字开头. python中的标识符是区分大小写的. 以 ...

  8. Visual Studio 使用及调试必知必会

    原文:Visual Studio 使用及调试必知必会   一:C# CODING 技巧 1:TODO 然后 CTRL + W + T,打开任务列表,选中 Comments,就会显示所有待做的任务 2: ...

  9. 关于fork&lpar;&rpar;函数的作用

    (1)    先看一个实例: #include <unistd.h>; #include <sys/types.h>; main () {           pid_t pi ...

  10. 识别图片中文字(百度AI)

     这个是百度官方的文档         https://ai.baidu.com/docs#/OCR-API/top    通用的文字识别,如果是其他的含生僻字/含位置信息的版本,请参考官方的文档,只 ...