mysql存储过程的初步学习及案例示例
存储过程
几个月前小编开始初步接触学习存储过程,当然是跟着大神的视频学习的,在学习的过程中自己也记录了一下笔记,如今整理一下,接下来我将从概念,优缺点以及语法和实际应用几方面为大家详细讲解一下存储过程,如有不对的地方,望留言批评,给予修正。
概念:一组预先编译好的sql语句的集合,理解成批处理语句。
优点:1.提高代码的重用性 2.简化操作 3.减少了我们的编译次数并且减少了服务器的连接次数,提高了效率。
语法:一、创建语法
create procedure 存储过程名称(参数列表)
begin
存储过程体(一组合法的sql语句)
end
注意:1.参数列表包含三部分:参数模式、参数名,参数类型
例如:in stuname varchar(20) ,其中“in”为参数模式,“stuname”为参数名,varchar(20)为参数类型。
这里重点说一下参数模式,参数模式有以下三种:
in该参数可以作为输入,也就是说该参数需要调入方传入值;
out:该参数可以作为输出,也就是该参数可以作为返回值;
inout:该参数既可以作为输入又可以作为输出,也就是该参数既需要传入值,又可以返回值。
2.如果存储过程仅仅只有一句话,begin end可以省略。存储过程体的每条sql语句的结尾要求必须加分号, 存储过程的结尾可以使用 delimiter 重新设置 语法: delimiter 结束标记 案例:delimiter $
二、调用语法
call 存储过程名(实体参数);
三、简单案例
1.空参列表 案例:插入到persion表中五条记录
delimiter $
create procedure myp1()
begin
insert into persion5(name,sex) values("张三",1),("汤姆",1),("李四",1),("王五",1);
end $
调用语法
call myp1();
2.创建一个in模式的存储过程
案例一:创建存储过程实现,根据姓名查询对应的信息
delimiter $
create procedure myp3(in beautyName varchar(20))
begin
select p.*
from persion5 p
where p.name = beautyName;
end $
调用语法
call myp3('张三')
;
案例二 创建存储过程用来传多个参数 in 模式
delimiter $
create procedure myp4(in inname varchar(20),in insex int)
begin
select if(p.name = inname and p.sex = insex,'查询出了数据','没有查询出数据') as result
from persion5 as p
where p.id = 9;
end $
call myp4('张三',2);
案例三 自己声明参数
delimiter $
create procedure myp5(in inname varchar(20),in insex int)
begin
declare result varchar(20) default '';#声明并初始化
select count(*) into result #赋值
from persion5 as p
where p.name = inname and p.sex = insex;
select result;#使用
end $
call myp5('王五',1);
3.创建一个out模式的存储过程
案例一:根据name ,返回sex
delimiter $
create procedure myp6(in inname varchar(20),in inid int,out outsex varchar(20))
begin
select p.name into outsex
from persion5 as p
where p.name = inname and p.id = inid;
end $
set @outsex = '';
call myp6('李四',3,@outsex);
select @outsex as '结果';
4 创建一个inout模式参数的存储过程
案例!、传入a和b两个值,最终a和b都翻倍并返回
delimiter $
create procedure myp7(inout a int,inout b int)
begin
set a = a*2;
set b = b*2;
end $
set @a=10;#声明一个变量a
set @b=20;#声明一个变量b
call myp7(@a,@b);#将变量a b传入到myp7中,返回的值存入先前声明的变量
SELECT @a,@b;#将变量输出
调用:需要先定义变量,
练习:
一、创建存储过程(略微提高难度)
实现往admin表中插入数据
delimiter $
create procedure test_pro1(in userName varchar(20),in loginPwd varchar(20))
begin
insert into admin(admin.username,admin.password)
VALUES (userName,loginPwd);
end $
call test_pro1('admiin','00001');
创建存储过程实现传入id,获取姓名以及地址
delimiter $
create procedure test_pro2(in inid int,out outName varchar(20),out outAdress varchar(20))
begin
select p.name ,p.adress into outName,outAdress
from persion p
where p.id = inid;
end $
set @outName = '';
set @outAdress = '';
call test_pro2(1,@outName,@outAdress);
select @outName as outName,@outAdress as outAdress;
创建存储过程用来实现比较大小
delimiter $
create procedure test_pro3(in birth1 DATETIME,in birth2 DATETIME,out result int)
begin
select DATEDIFF(birth1,birth2) into result;#调用比较日期大小的函数
end $
call test_pro3('2998-1-1',now(),@result);#传入两个时间,now()/取当前的时间
select @result;
二、删除存储过程
语法 drop procedure 存储过程名称 注意:只能删除一条
drop procedure test_pro5;
三、查看存储过程的信息
show create procedure '存储名称';
show create procedure myp1;
四、创建存储过程或者函数实现传入一个日期,格式化成XX年XX月XX日并返回
delimiter $
create procedure test_pro4(in mydata datetime,out strdate varchar(20))
begin
select DATE_FORMAT(mydata,'%Y年%c月%e日') into strdate;
end $
call test_pro4(now(),@str);
select @str as '格式化日期';
五 传入姓名,查出姓名 and 地址
delimiter $
create procedure test_pro5(in myName varchar(20),out str varchar(20))
begin
select concat(myName,' and ',IFNULL(p.adress,'111')) into str
from persion p
where p.name = myName;
end $
call test_pro5('李白',@str);
select @str;
六 创建存储过程,根据传入的条目数和起始索引,查询记录
delimiter $
create procedure test_pro6(in startIndex int,in size int)
begin
select *
from persion5 limit startIndex,size;
end $
call test_pro6(2,5);
在学习存储过程的过程中还需要注意的一点是与mysql函数的比较区分,在这里主要讲解的是存储过程的初步学习,函数方面就不做过多介绍了,后期有机会的话讲解一下函数。本篇存储过程的讲解适合初学者,更复杂的还需要大家和小编一块努力探究学习。
mysql存储过程的初步学习及案例示例的更多相关文章
- MYSQL存储过程和函数学习笔记
学至Tarena金牌讲师,金色晨曦科技公司技术总监沙利穆课程笔记的综合. 1. 什么是存储过程和函数 将SQL语句放入一个集合里,然后直接调用存储过程和函数来执行已经定义好的SQL语句,通过存储过程和 ...
- 创建MySQL存储过程示例
创建MySQL存储过程是学习MySQL数据库必须要掌握的知识,下文对创建MySQL存储过程作了详细的介绍,供您参考学习. AD:2013大数据全球技术峰会课程PPT下载 下文将教您如何创建MySQL存 ...
- Mysql存储过程知识,案例--mysql存储过程基本函数
Mysql存储过程知识,案例: create procedure delete_setting(in p_settingid integer) begin delete from setting wh ...
- MySQL存储过程学习笔记
MySQL在5.0以前并不支持存储过程,这使得MySQL在应用上大打折扣.MySQL 5.0终于开始支持存储过程了. MySQL的关键字大小写通用.该学习笔记对关键字使用大写:变量名,表名使用小写. ...
- MySQL 存储过程学习笔记
存储过程框架 DEMILITER $$ -- 重定义符 DROP PROCEDURE IF EXISTS store_procedure$$ -- 如果存在此名的存储过程,先删除 CREATE PRO ...
- MySQL 存储过程传参数实现where id in(1,2,3,...)示例
一个MySQL 存储过程传参数的问题想实现例如筛选条件为:where id in(1,2,3,...),下面有个不错的示例,感兴趣的朋友可以参考下 正常写法: ,,,,...); 当在写存储过程 ...
- MYSQL存储过程初步认知
存储过程(Stored Procedure): 一组可编程的函数,是为了完成特定功能的SQL语句集,经编译创建并保存在数据库中,用户可通过指定存储过程的名字并给定参数(需要时)来调用执行. 优点:将重 ...
- python预课04 列表,元祖,统计值计算示例,py文件转为EXE文件,爬虫初步学习
列表,元组 #list l1 = [1, 2, 3, '高弟弟'] #定义一个列表 #增 l1.append("DSB") #最后增加"DSB"的元素 #删 l ...
- mysql 存储过程学习
存储过程框架 DEMILITER $$ -- 重定义符 DROP PROCEDURE IF EXISTS store_procedure$$ -- 如果存在此名的存储过程,先删除 CREATE PRO ...
随机推荐
- 如何为指定python解释器安装pip
有时候我们通常会有很多python解释器,例如python2.python3.python(Anaconda). 参考链接:https://www.cnblogs.com/michaelcjl/p/1 ...
- Better Key Sizes (and Attacks) for LWE-Based Encryption
郑重声明:原文参见标题,如有侵权,请联系作者,将会撤销发布! 以下是对本文关键部分的摘抄翻译,详情请参见原文 Abstract 基于“learning with errors”(LWE)问题,分析了理 ...
- 学习一下 JVM (二) -- 学习一下 JVM 中对象、String 相关知识
一.JDK 8 版本下 JVM 对象的分配.布局.访问(简单了解下) 1.对象的创建过程 (1)前言 Java 是一门面向对象的编程语言,程序运行过程中在任意时刻都可能有对象被创建.开发中常用 new ...
- smtplib文字邮件的发送
今天跟大家讲解一下接口测试框架的知识准备阶段,首先是发送纯文字的电子邮件,会的同学可以忽略,不会的就多敲几遍,直到自己能敲出来为止~~ # coding: utf-8import smtplibfro ...
- C++入门记-大纲
缘来 由于某个不可告人的目标以及想趁着还有精力的年龄,开始了C++学习之路.C++ 诞生很多年了,但依然具有强大的生命力. 我们来看下2020年8月TIOBE 8 月编程语言排行榜. 可以看到C以及C ...
- go语言之反射
---恢复内容开始--- 一 :并发基础 1 并发和并行 并发和并行是两个不同的概念: 并行意味着程序在任意时刻都是同时运行的: 并发意味着程序在单位时间内是同时运行的 详解: 并行就是在任一粒度的时 ...
- Visual Studio Installer闪退问题解决方法
Visual Studio 2019安装推荐的方式是通过官方给的Installer进行的(2017也是同样方法),但是有时会出现在”即将完成…一切即将准备就绪“这个界面闪退的问题,导致软件的安装.卸载 ...
- WebStorm下ReactNative代码提示设置
ReactNative 代码智能提醒 (Webstrom live template) https://github.com/virtoolswebplayer/ReactNative-LiveTe ...
- 利用负margin-bottom去除列表最后一个li元素的border-bottom
负margin-bottom不会影响元素的实际大小,只会使得后面的元素上移 以第二个里为例,由于第一个li的margin-bottom导致第二个li被上拉1px,第二个li最上面的1px高度覆盖在第一 ...
- 0 mysql 安装
1 安装网址 https://dev.mysql.com/downloads/installer/ 选择 mysql server版本一路next 2.配置环境 mysql 默认安装位置是: C:\P ...