MySQL数据库新特性之存储过程入门教程

MySQL数据库新特性之存储过程入门教程,第1张

在MYSQL 中 终于引入了存储过程这一新特性 这将大大增强MYSQL 的数据库处理能力 在本文中 将指导读者快速掌握MYSQL 的存储过程的基本知识 带领用户入门

存储过程介绍

存储过程是一组为了完成特定功能的SQL语句集 经编译后存储在数据库中 用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它 存储过程可由应用程序通过一个调用来执行 而且允许用户声明变量 同时 存储过程可以接收和输出参数 返回执行存储过程的状态值 也可以嵌套调用

存储过程的优点

作为存储过程 有以下这些优点

( )减少网络通信量 调用一个行数不多的存储过程与直接调用SQL语句的网络通信量可能不会有很大的差别 可是如果存储过程包含上百行SQL语句 那么其性能绝对比一条一条的调用SQL语句要高得多

( )执行速度更快 存储过程创建的时候 数据库已经对其进行了一次解析和优化 其次 存储过程一旦执行 在内存中就会保留一份这个存储过程 这样下次再执行同样的存储过程时 可以从内存中直接中读取

( )更强的安全性 存储过程是通过向用户授予权限(而不是基于表) 它们可以提供对特定数据的访问 提高代码安全 比如防止 SQL注入

( ) 业务逻辑可以封装存储过程中 这样不仅容易维护 而且执行效率也高

当然存储过程也有一些缺点 比如

可移植性方面 当从一种数据库迁移到另外一种数据库时 不少的存储过程的编写要进行部分修改

存储过程需要花费一定的学习时间去学习 比如学习其语法等

在MYSQL中 推荐使用MYSQL Query Browswer()这个工具去进行存储过程的开发和管理 下面分步骤来学习MYSQL中的存储过程

定义存储过程的结束符

在存储过程中 通常要输入很多SQL语句 而SQL语句中每个语句以分号来结束 因此要告诉存储过程 什么位置是意味着整个存储过程结束 所以我们在编写存储过程前 先定义分隔符 我们这里定义 // 为分隔符 我们使用DELIMITER //这样的语法 就可以定义结束符了 当然你可以自己定义其他喜欢的符号

如何创建存储过程

下面先看下一个简单的例子 代码如下

DELIMITER //CREATEPROCEDURE `p ` ()LANGUAGE SQLDETERMINISTICSQL SECURITY DEFINERMENT  A procedure BEGINSELECT Hello World ! END//

下面讲解下存储过程的组成部分

)首先在定义好终结符后 使用CREATE PROCEDURE+存储过程名的方法创建存储过程 LANGUAGE选项指定了使用的语言 这里默认是使用SQL

)DETERMINISTIC关键词的作用是 当确定每次的存储过程的输入和输出都是相同的内容时 可以使用该关键词 否则默认为NOT DETERMINISTIC

) SQL SECURITY关键词 是表示调用时检查用户的权限 当值为INVOKER时 表示是用户调用该存储过程时检查 默认为DEFINER 即创建存储过程时检查

) MENT部分是存储过程的注释说明部分

lishixinzhi/Article/program/MySQL/201404/30557

MS

SQL基础教程:创建存储过程

在MS

SQL

Server

2000

中,创建一个存储过程有两种方法:一种是使用Transaction-SQL

命令Create

Procedure,

另一种是使用图形化管理工具Enterprise

Manager。

用Transaction-

SQL

创建存储过程是一种较为快速的方法,但对于初学者,使用Enterprise

Manager

更易理解,更为简单。

当创建存储过程时,需要确定存储过程的三个组成部分

所有的输入参数以及传给调用者的输出参数。

被执行的针对数据库的 *** 作语句,包括调用其它存储过程的语句

返回给调用者的状态值,以指明调用是成功还是失败。

12.2.1

使用Enterprise

Manager

创建存储过程

按照下述步骤用Enterprise

Manager

创建一个存储过程:

启动Enterprise

Manager,

登录到要使用的服务器。

选择要创建存储过程的数据库,在左窗格中单击Stored

Procedure

文件夹,此时在右窗格中显示该数据库的所有存储过程,如图12-1

所示。

右击Stored

Procedure

文件夹,在d出菜单中选择New

Stored

Procedure,

此时打开创建存储过程对话框,

输入存储过程正文。

单击Check

Syntax,

检查语法是否正确。

单击OK,

保存。

在右窗格中,右击该存储过程,在d出菜单中选择All

task,

选择

ManagePermissions,

设置权限,

12.2.2

用CREATE

PROCEDURE

命令创建存储过程

通过运用Create

Procedure

命令能够创建存储过程,在创建存储过程之前,应该考虑到以下几个方面:

在一个批处理中,Create

Procedure

语句不能与其它SQL

语句合并在一起

数据库所有者具有默认的创建存储过程的权限,它可把该权限传递给其它的用户

存储过程作为数据库对象其命名必须符合命名规则

只能在当前数据库中创建属于当前数据库的存储过程。

用Create

Procedure

创建存储过程的语法规则如下:

CREATE

PROC

[

EDURE

]

procedure_name

[

number

]

[

{

@parameter

data_type

}

[

VARYING

]

[

=

default

]

[

OUTPUT

]

]

[

,...n

]

[

WITH

{

RECOMPILE

|

ENCRYPTION

|

RECOMPILE

,

ENCRYPTION

}

]

[

FOR

REPLICATION

]

AS

sql_statement

[

...n

]


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9678993.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存