`
sogo6
  • 浏览: 113314 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

mysql 存储过程入门

阅读更多
    我们大家都知道MySQL 存储过程是从 MySQL 5.0 开始逐渐增加新的功能。存储过程在实际应用中也是优点大于缺点。不过最主要的还是执行效率和SQL 代码封装。特别是 SQL 代码封装功能,如果没有存储过程。

    在外部程序访问数据库时(例如 PHP),要组织很多 SQL 语句。

    特别是业务逻辑复杂的时候,一大堆的 SQL 和条件夹杂在 PHP 代码中,让人不寒而栗。现在有了 MySQL 存储过程,业务逻辑可以封装存储过程中,这样不仅容易维护,而且执行效率也高。

一、MySQL 创建存储过程

“pr_add” 是个简单的 MySQL 存储过程,这个MySQL 存储过程有两个 int 类型的输入参数 “a”、“b”,返回这两个参数的和。

drop procedure if exists pr_add;[/sql]

计算两个数之和
create procedure pr_add(a int, b int)
begin   
    declare c int;   
    if a is null then   
        set a = 0;   
    end if;   
    if b is null then   
        set b = 0;   
    end if;
    set c = a + b;   
    select c as sum;   
    /*
    return c; 不能在 MySQL 存储过程中使用。return 只能出现在函数中。
    */   
end;

 
二、调用 MySQL 存储过程

call pr_add(10, 20);


执行 MySQL 存储过程,存储过程参数为 MySQL 用户变量。

set @a = 10;  
set @b = 20;  
call pr_add(@a, @b);

三、MySQL 存储过程特点

创建 MySQL 存储过程的简单语法为:

create procedure 存储过程名字()   
( 
[in|out|inout] 参数 datatype   
)   
begin
    MySQL 语句;   
end;  

MySQL 存储过程参数如果不显式指定“in”、“out”、“inout”,则默认为“in”。习惯上,对于是“in” 的参数,我们都不会显式指定。

1. MySQL 存储过程名字后面的“()”是必须的,即使没有一个参数,也需要“()”

2. MySQL 存储过程参数,不能在参数名称前加“@”,如:“@a int”。下面的创建存储过程语法在 MySQL 中是错误的(在 SQL Server 中是正确的)。 MySQL 存储过程中的变量,不需要在变量名字前加“@”,虽然 MySQL 客户端用户变量要加个“@”。

create procedure pr_add  
(  
@a int, -- 错误  
b int -- 正确  

3. MySQL 存储过程的参数不能指定默认值。

4. MySQL 存储过程不需要在 procedure body 前面加 “as”。而 SQL Server 存储过程必须加 “as” 关键字。

create procedure pr_add   
(   
a int,   
b int   
)   
as -- 错误,MySQL 不需要 “as”   
begin   
    mysql statement ...;   
end;


5. 如果 MySQL 存储过程中包含多条 MySQL 语句,则需要 begin end 关键字。

create procedure pr_add   
(   
a int,   
b int   
)   
begin   
    mysql statement 1 ...;   
    mysql statement 2 ...;   
end; 

6. MySQL 存储过程中的每条语句的末尾,都要加上分号 “;”

...   
declare c int;   
if a is null then   
    set a = 0;   
end if;   
...   
end;


7. MySQL 存储过程中的注释。

/*   
这是个   
多行 MySQL 注释。   
*/   
declare c int; -- 这是单行 MySQL 注释 (注意 -- 后至少要有一个空格)   
if a is null then # 这也是个单行 MySQL 注释   
    set a = 0;   
end if;   
...   
end; 

8. 不能在 MySQL 存储过程中使用 “return” 关键字。

set c = a + b;   
select c as sum;   
/*   
return c; -- 不能在 MySQL 存储过程中使用。return 只能出现在函数中。   
*/   
end;


9. 调用 MySQL 存储过程时候,需要在过程名字后面加“()”,即使没有一个参数,也需要“()”
call pr_no_param();

10. 因为 MySQL 存储过程参数没有默认值,所以在调用 MySQL 存储过程时候,不能省略参数。可以用 null 来替代。
分享到:
评论

相关推荐

    MySQL 存储过程入门到精通

    在这个“MySQL存储过程入门到精通”资料中,你将深入理解存储过程的原理、创建、调用以及优化方法。 一、存储过程的基本概念 存储过程是由一系列SQL语句组成的程序,存储在数据库服务器上,可以被多次调用执行,...

    MySQL存储过程入门学习

    ### MySQL存储过程入门学习 #### 一、存储过程概述 **存储过程**(Stored Procedure)是一种在数据库中存储的预先编写并编译好的SQL程序或函数集合。存储过程的主要优势在于可以提高应用程序的性能和响应速度,同时...

    完整版 MySQL8.0从入门到精通 MySQL数据库教程 全套PPT课件资源集合 共26个章节 含全部源代码.rar

    完整版 MySQL8.0从入门到精通 MySQL数据库教程 第21章 精通MySQL存储引擎(共31页).ppt 完整版 MySQL8.0从入门到精通 MySQL数据库教程 第22章 PHP操作MySQL数据库(共16页).ppt 完整版 MySQL8.0从入门到精通 MySQL...

    小题大做之MySQL 5.0存储过程编程入门(转)

    MySQL 5.0 存储过程编程入门是数据库管理领域中的一个重要话题,它涉及到数据库的高级功能,使得数据库系统能够执行复杂的逻辑操作,提高数据处理的效率和安全性。存储过程是一组预先编译的SQL语句,可以在需要时被...

    MySQL存储过程pdf

    本PDF教程全面覆盖了从入门到精通的MySQL存储过程知识,旨在帮助读者深入理解并熟练掌握这一技能。 一、存储过程的基本概念 存储过程是由一系列SQL语句组成的程序,存储在数据库服务器中,可以被多次调用,减少了...

    MySQL课程之MySQL存储引擎入门

    MySQL是世界上最流行的关系型数据库管理系统之一,其强大的功能和灵活性主要得益于它支持多种存储引擎。在MySQL课程中,深入理解存储引擎是至关重要的,因为不同的存储引擎有着不同的特性和适用场景,这直接影响到...

    MySQL5.7从入门到精通 带书签 高清

    这份“MySQL5.7从入门到精通”的资源旨在为初学者和有经验的开发者提供一个全面的学习指南,通过高清带书签的PDF文档,使得学习过程更加高效和便捷。 一、MySQL基础 MySQL的基础部分通常包括数据库的概念、安装与...

    详解MySql存储过程参数的入门使用

    存储过程 in参数 的使用 IN参数只用来向过程传递信息,为默认值。 -- 存储过程中 in 参数的 使用 DELIMITER ;; CREATE PROCEDURE name_in(IN `time` VARCHAR(50)) BEGIN SELECT NOW() ,`time`; END ;; CALL name_in...

    完整精品数据库课件 MySQL从入门到精通 第10章 存储过程和函数(共19页).ppt

    MySQL是世界上最流行的关系型数据库管理系统之一,而存储过程和函数是其强大功能的重要组成部分。本章节将深入探讨这两个概念,以及如何在MySQL中创建、调用、查看、修改和删除它们。 1. **创建存储过程和函数** -...

    在MySQL中创建带有IN和OUT参数的存储过程的方法

    在MySQL 入门教程中,我们能够看到很多关于如何创建储存过程 和如何利用 IN 和 OUT 参数调用存储过程的示例。这些示例都很简单,能够很好的帮助你理解 MySQL 中创建带参数存储过程的语法。这些示例已在 MySQL 5.5 中...

    mysql 4从入门到精通

    《MySQL从入门到精通》这本书是为初学者和有一定基础的数据库管理员设计的,它全面覆盖了MySQL的基础知识...希望你在阅读《MySQL从入门到精通》的过程中,不仅能掌握数据库的基础知识,还能培养出解决实际问题的能力。

    mysql 5.7从入门到精通

    MySQL 5.7是世界上最流行的开源关系型数据库管理系统之一,被广泛应用于Web应用程序、电子商务、数据分析...《MySQL5.7从入门到精通》这本书应该会提供详尽的教程和实例,帮助你在学习过程中更好地理解和掌握这些内容。

    MySql零基础入门到精通(资料集)SQL语句+触发器+存储过程+安装卸载+导入导出+性能优化

    第二阶段---MySQL存储过程实例教程.doc 第二阶段---MYSQL存储过程技术ppt 第二阶段---MySQL导入导出数据库文件.doc 第二阶段---Mysgl数据类型(字段)介绍.doc 第二阶段---MySQL样例数据库、操作库操作表实例教程.doc ...

    MySQL从入门到实战学习教程之10存储过程.pptx

    MySQL存储过程详解 MySQL存储过程是MySQL中常用的数据库对象,它是一组为了完成特定功能的预编译的SQL语句集合。存储过程是一种命名的程序块,在第一次使用经过编译之后,再次调用时不用再编译,因此执行效率较高。...

    存储过程从入门到熟练(多个存储过程完整实例及调用方法)

    在实践中,了解如何在各种数据库系统(如MySQL、SQL Server、Oracle等)中创建和调用存储过程也是重要的。每个系统可能有不同的语法和特性,但基本原理是一致的。 通过阅读"存储过程从入门到熟练"这份文档,你将有...

    mysql存储过程的使用

    使用python语言,Django框架,实现调用mysql存储过程。包括通过Navicat工具在mysql数据库中创建存储过程的方法,django配置文件,路由规则,前端页面的使用,通过类实现get和post请示。 适合人群: 初学或刚入门的...

    MySQL5.7从入门到精通》

    7. **存储过程和函数**:编写和调用存储过程和用户定义函数,了解它们在提高代码复用性和安全性方面的价值。 8. **事务处理**:理解事务的开始、提交、回滚以及隔离级别,学习如何在MySQL中实现事务控制。 9. **...

    mysql5.5从入门到精通.pdf

    以下是对"mysql5.5从入门到精通.pdf"文档中可能涵盖的一些关键知识点的详细解释: 1. **安装与配置**: - MySQL的安装过程,包括Windows、Linux和macOS等不同操作系统的安装方法。 - 配置my.cnf文件,调整数据库...

    MySQL入门+进阶资源合集.pdf

    ### MySQL入门+进阶资源合集 #### 一、MySQL基础知识与入门 ##### 1.1 MySQL基础概念 - **数据库(Database)**:是用于存储数据的逻辑容器,它能够高效地管理和组织数据。 - **表(Table)**:是数据库中用来存储...

    MySQL数据库入门.rar

    2. "01-MySQL数据库入门 教学设计.doc":这部分可能详细介绍了MySQL的背景,安装过程,以及基本的数据库概念。 3. "02-数据库和表的基本操作 教学设计.doc":这里将介绍如何创建数据库,定义表结构,以及插入、查询...

Global site tag (gtag.js) - Google Analytics