MySQL数据库存储过程讲解与实例
存储过程简介
SQL语句需要先编译然后执⾏,⽽存储过程(Stored Procedure)是⼀组为了完成特定功能的SQL语句集,经编译后存储在数据库中,⽤户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调⽤执⾏它。
存储过程是可编程的函数,在数据库中创建并保存,可以由SQL语句和控制结构组成。当想要在不同的应⽤程序或平台上执⾏相同的函数,或者封装特定功能时,存储过程是⾮常有⽤的。数据库中的存储过程可以看做是对编程中⾯向对象⽅法的模拟,它允许控制数据的访问⽅式。
存储过程的优点:
(1).增强SQL语⾔的功能和灵活性:存储过程可以⽤控制语句编写,有很强的灵活性,可以完成复杂的判断和较复杂的运算。
(2).标准组件式编程:存储过程被创建后,可以在程序中被多次调⽤,⽽不必重新编写该存储过程的SQL语句。⽽且数据库专业⼈员可以随时对存储过程进⾏修改,对应⽤程序源代码毫⽆影响。
(3).较快的执⾏速度:如果某⼀操作包含⼤量的Transaction-SQL代码或分别被多次执⾏,那么存储过程要⽐批处理的执⾏速度快很多。因为存储过程是预编译的。在⾸次运⾏⼀个存储过程时查询,优化器对其进⾏分析优化,并且给出最终被存储在系统表中的执⾏计划。⽽批处理的Transaction-SQL语句在每次运⾏时都要进⾏编译和优化,速度相对要慢⼀些。
(4).减少⽹络流量:针对同⼀个数据库对象的操作(如查询、修改),如果这⼀操作所涉及的Transaction-SQL语句被组织进存储过程,那么当在客户计算机上调⽤该存储过程时,⽹络中传送的只是该调⽤语句,从⽽⼤⼤减少⽹络流量并降低了⽹络负载。
(5).作为⼀种安全机制来充分利⽤:通过对执⾏某⼀存储过程的权限进⾏限制,能够实现对相应的数据的访问权限的限制,避免了⾮授权⽤户对数据的访问,保证了数据的安全。
MySQL的存储过程
存储过程是数据库的⼀个重要的功能,MySQL 5.0以前并不⽀持存储过程,这使得MySQL在应⽤上⼤打折扣。好在MySQL 5.0开始⽀持存储过程,这样即可以⼤⼤提⾼数据库的处理速度,同时也可以提⾼数据库编程的灵活性。index match函数含义
jdk安装及环境配置
MySQL存储过程的创建
语法如下:
CREATE PROCEDURE  过程名([[IN|OUT|INOUT] 参数名数据类型[,[IN|OUT|INOUT] 参数名数据类型…]]) [特性 ...] 过程体
DELIMITER //
CREATE PROCEDURE myproc(OUT s int)
BEGIN
SELECT COUNT(*) INTO s FROM students;
END
//
DELIMITER ;
分隔符:MySQL默认以";"为分隔符,如果没有声明分割符,则编译器会把存储过程当成SQL语句进⾏处理,因此编译过程会报错,所以要事先⽤“DELIMITER //”声明当前段分隔符,让编译器把两个"//"之
间的内容当做存储过程的代码,不会执⾏这些代码;“DELIMITER ;”的意为把分隔符还原。
参数:存储过程根据需要可能会有输⼊、输出、输⼊输出参数,如果有多个参数⽤","分割开。MySQL存储过程的参数⽤在存储过程的定义,共有三种参数类型,IN,OUT,INOUT:
IN参数的值必须在调⽤存储过程时指定,在存储过程中修改该参数的值不能被返回,为默认值OUT:该值可在存储过程内部被改变,并可返回INOUT:调⽤时指定,并且可被改变和返回。
过程体:过程体的开始与结束使⽤BEGIN与END进⾏标识。
MySQL实例与讲解
1. 创建⼀存储过程,求l+2+3+…+n,并打印结果。
先使⽤MySQL语句创建存储过程,再使⽤call语句调⽤这⼀存储过程查看结果,可以看到由于未输⼊n的值,sum结果为0。
2.调⽤上⾯的addresult存储过程,打印l⼗2+3+…+10的结果。
在第⼀题的addresult过程基础上,加上⼀条“set n=10”语句,设定n的值,调⽤该过程后打印结果,可以看到结果为sum=1+2+3+...+10=55。
3. 修改上述存储过程为addresult1,使得n为输⼊参数,其具体值由⽤户调⽤此存储过程时指定。
在这⾥需要注意的是,MySQL存储过程只能改名字和定义,不能改⾥⾯的内容。要删了重新建。所以这⾥选择重新建⽴⼀个addresult1过程,调⽤后输⼊n,查看打印结果。
4.调⽤上⾯修改后的addresult1存储过程,打印l+2+3+…+100的结果。
调⽤上述过程,输⼊参数n为100,可以看到打印结果中sum=5050,结果正确。
5. 修改上述存储过程为addresult2,将n参数设定默认值为10,并改设sum为输出参数,让主程序能够接收计算结果。angular select设置默认选中
将3中存储过程中的“in n int”修改为“out sum int”,并在存储过程中设定n默认值为10。
mysql查看所有存储过程6.调⽤上⾯修改后的addresult2存储过程,设置变量接收计算l+2+3+…+10的结果。
调⽤addresult2过程,可以看到输出结果sum=55。
7.创建⼀存储过程Proc_Student,⽤于显⽰学号为“0102”的学⽣基本信息(包括学号、姓名、性别和系)。常量元素的英文缩写
创建存储过程,将查询语句写在存储过程中,相当于将⼀个查询语句封装在存储过程中,通过调⽤这个存储过程,便可执⾏该查询操作。
8.创建⼀存储过程Stu_grade,通过读取某门课的编号,求出不及格的学⽣的学号。
同上⼀题,将查询过程封装在存储过程中,并且使⽤“int ID int”来实现课程编号的⾃定义输⼊,再根据输⼊的课程编号进⾏查询。
9.调⽤上⾯的存储过程Stu_grade,求出课程编号为“0101”的不及格的学⽣。
调⽤存储过程Stu_grade,输⼊课程编号为“0101”,查看打印结果。
10.创建⼀存储过程avgGrade,通过读取学⽣的学号,以参数形式返回该学⽣的平均分。
在创建存储过程时,设定学号为输⼊,平均成绩为输出,且因为平均成绩可能出现⼩数,所以设定其数据类型为float。通过select语句将平均分以参数形式返回。
11.调⽤上⾯的存储过程avgGrade,求出学号为“990102014”的平均分。
输⼊学号与输出参数,可以看到该学⽣的平均成绩被打印出来。
c语言运算符使用
12.删除上述存储过程avgGrade。
对于存储过程的删除,使⽤drop语句即可。
DROP PROCEDURE avgGrade;
13.创建存储过程search,该存储过程有三个参数,分别为t、p1,p2,根据这些参数,出书名与t
有关,价格在p1与p2(p2>=p1)之间的书的编号,书名,价格,出舨⽇期。如果⽤户调⽤时没有指定t参数的值.则表⽰可为任意值,如⽤户没有指定p2,则书本价格没有上限。⽤到的关系为:titles (title_id,title,price,pubdate)。
14.调⽤上⾯的存储过程search,求出书名与computer有关,⽽且价格⼩于$20⼤于$10的书。
调⽤存储过程search,将参数computer,10,20传⼊,查看打印结果。
请⾃⾏测试。
总结:
本次主要是掌握了对于存储过程的使⽤,总的来说,存储过程实际上类似于C++中的函数,⽽在C++中我们是需要在创建这⼀过程的⽂件中去调⽤这⼀函数,但是对于存储过程来说,相当于是将这⼀操作过程存储在数据库中,可以使⽤call与对其进⾏调⽤,并输⼊或者输出⼀些参数和结果。
印象最深的是类似“in n int”和“out sum int”这样的对于输⼊输出的定义,可以总结如下对于输⼊输出定义的使⽤规律:
MySQL存储过程的参数⽤在存储过程的定义,共有三种参数类型

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。