设为首页 加入收藏

TOP

mysql存储过程及常用函数(二)
2014-11-23 23:12:31 来源: 作者: 【 】 浏览:17
Tags:mysql 存储 过程 常用 函数
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;

存储过程运行于服务器端,运行速度比较快,而且存储过程执行一次,它的执行规范驻留在高速缓冲存储器中,在以后的

操作中只需要从高速缓冲存储器调用已编译好的二进制代码,提高系统性能和系统响应时间。也可以确保存储过程安全,因为我们使用存储过程可以完成数据库的所有操作,也可以通过编程的方式来控制对数据库操作的访问权限。

首页 上一页 1 2 下一页 尾页 2/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇用ADO更新MYSQL报“无法为更新定.. 下一篇mysql5.1,5.5,5.6做partition时支..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: