长沙创求网络科技有限公司,关键词优化的发展趋势,网络工程师免费教程,ppt模板图片素材存储过程
1、存储过程简介 存储过程与函数的直接效果类似#xff0c;只不过存储过程#xff0c;封装的是一组sql语句。
mysql数据库存储过程是一组为了完成特定功能的sql语句的集合。 存储过程这个功能时从5.0版本才开始支持的#xff0c;它可以加快数据库的处理速度只不过存储过程封装的是一组sql语句。
mysql数据库存储过程是一组为了完成特定功能的sql语句的集合。 存储过程这个功能时从5.0版本才开始支持的它可以加快数据库的处理速度增强数据库在实际应用中的灵活性。 存储过程在使用过程中是将常用或复杂的工作预先使用sql语句写好并用一个指定的名称存储起来这个过程编译和优化后存储在数据库服务器中当需要使用该存储过程时只需要调用它即可。 操作数据库的传统sql语句在执行时需要先编译然后再去执行跟存储过程一对比明显存储过程在执行速度更快效率更高。存储过程在数据库中创建并保存。它不仅仅是sql了语句的集合还可以加入一些特殊的控制结构也可以控制数据的访问方式。
2、存储过程的优点 执行一次后会将生成的二进制代码驻留缓冲区提高执行效率 sql语句加上控制语句的集合灵活性高 在服务器端存储客户端调用时降低网络负载 可多次重复被调用可随时修改不影响客户端调用。 可完成所有的数据库操作也可控制数据库的信息访问权限3、语法 create procedure 过程名 ([过程参数....]) 过程体 [过程参数....] 格式 过程名尽量避免与内置的函数或字段重名 过程体语句 [in|out|inout] 参数名类型4、不带参数的存储过程创建 mysql delimiter ##将语句的结束符号从分号临时修改为以防出问题可以自定义 mysql create procedure proc() #创建存储过程过程名自定义()可带参数 - begin #过程体以关键字begin开始 - select * from info; #过程体语句(可有多条) - end #过程体以关键字end结尾 mysql delimiter ; #将语句的结束符号恢复为分号 mysql show create procedure proc\G #查看存储过程信息 mysql call proc(); #调用存储过程
5、带参数的存储过程创建 in输入参数 in 表示调用者向过程传入值传入值可以是字面量或变量
out输出参数 out表示过程向调用者传出值可以返回多个值传出值只能是变量
inout输入/输出参数 inout即表示调用者向过程传入值又表示过程向调用者传入值只能是变量
mysql delimiter mysql create procedure proc01 (in inname varchar(40)) #行参 - begin - select * from info where nameinname; - end mysql delimiter ; mysql call proc01(wangwu); #实参
6、删除存储过程 drop procedure if exists proc; #删除proc存储过程
三、总结 存储过程是将一些sql语句存储在集合里面当需要执行这些语句的时候就可进行call调用这个存储过程整体逻辑跟shell中函数一致。
主要可避免提高执行sql语句的效率、提高灵活率。