#存储过程
/*
一组预先编译好的sql语句集合,理解成批处理语句 好处:
1、提高代码重用性
2、简化操作
3、减少了编译次数并减少了和数据库服务器的连接次数,提高了效率
*/ #一、创建
/*
create procedure 存储过程名(参数列表)
begin
一组合法的sql语句
end 注意:
1、参数列表
参数模式 参数名 参数类型
in stuname varchar(20) 2、参数模式
in 该参数可以作为输入,传入值
out 该参数可以作为输出,返回值
inout 输入输出都可以 3、如果存储过程体只有一句话,begin end可以省略 4、存储体中,每条sql语句的结尾要求必须加分号;存储过程的结尾可以用delimiter重新设置
*/ #二、调用
/*
call 存储过程名(实参列表);
*/ #1、空参列表
#案例:插入到admin表中五条记录
use girls;
select * from admin; delimiter &
create procedure myp1()
begin
insert into admin(username, password)
values('john1', '0000'), ('lily', '1000');
end & call myp1()&
select * from admin& #2、创建带in模式参数的存储过程
#案例1:根据女生名,查询对应的男生信息
delimiter &
create procedure mpv2(
in beauty_name varchar(20)
)
begin
select bo.*
from beauty as b
left join boys as bo
on bo.id = b.boyfriend_id
where b.name=beauty_name;
end & call mpv2('柳岩')& #案例2:创建存储过程实现,用户是否登录成功
create procedure mpv3(
in username varchar(20),
in password varchar(20)
)
begin
declare result varchar(20) default '';
select count(*) into result #赋值
from admin
where admin.username = username and admin.password = password;
select if(result>0, '成功', '失败');
end& call mpv3('张飞', '8888')&
call mpv3('john', '8888')& #3、创建带out模式的存储过程
#案例1:根据女生名,返回对应的男生名
create procedure mpv4(
in beautyName varchar(20),
out boyName varchar(20)
)
begin
select bo.boyName into boyName
from boys as bo
inner join beauty as b on bo.id = b.boyfriend_id
where b.name = beautyName;
end& #调用
call mpv4('小昭', @bName)&
select @bName; #4、带inout模式的存储过程
#案例1:传入a和b两个值,最终a和b都翻倍并返回
create procedure mpv5(
inout a int,
inout b int
)
begin
set a = a*2;
set b = b*2;
end& set @v1 = 10&
set @v2 = 20&
call mpv5(@v1, @v2)&
select @v1, @v2& #存储过程的删除
#只能一次删一个
# drop procedure 存储过程名; #查看存储过程
show create procedure mpv5; delimiter ;

  

mysql-17-procedure的更多相关文章

  1. MySQL中Procedure事务编写基础笔记

    原文:MySQL中Procedure事务编写基础笔记 目录: 一.PROCEDURE: 二.CREATE PROCEDURE基本语法: 三.PROCEDURE小进阶   3.1.基本的DECLARE语 ...

  2. MySQL Error: PROCEDURE xmdk.query_all_plan can't return a result set in the given context

    C++调用存储过程失败!出现如下错误:MySQL Error: PROCEDURE xmdk.query_all_plan can't return a result set in the given ...

  3. csharp: MySQL Stored Procedure using DAL

    # 建表 塗聚文 20160907 drop table attendrecord; create table attendrecord ( seq INT NOT NULL PRIMARY KEY ...

  4. MySQL:procedure, function, cursor,handler

    Procedure & Function Procedure 语法: CREATE [DEFINER = { user | CURRENT_USER }] PROCEDURE sp_name ...

  5. MYSQL alter procedure alter function 它们只可以更改过程的特性,不可以更改过程的逻辑。

    例子: delimiter // create procedure proc_a(in numberA int) 这样create procedure 是正确的 begin select number ...

  6. mysql存储过程procedure

    传送门 http://www.blogjava.net/sxyx2008/archive/2009/11/24/303497.html ) ); DROP PROCEDURE IF EXISTS ju ...

  7. mysql store procedure 存储过程

    参考资料: 1.http://blog.sina.com.cn/s/blog_52d20fbf0100ofd5.html 2.https://dev.mysql.com/doc/refman/5.7/ ...

  8. mysql存储过程(procedure)

    #创建带参数的存储过程 delimiter // ),out p int) begin ; end // delimiter call pro_stu_name_pass(@n,@p); select ...

  9. 所有子节点、Procedure、MySQL

    在Oracle 中我们知道有一个 Hierarchical Queries 通过CONNECT BY 我们可以方便的查了所有当前节点下的所有子节点.但很遗憾,在MySQL的目前版本中还没有对应的功能. ...

  10. 初习mysql procedure

    1.存储过程简介 我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户 ...

随机推荐

  1. FormData格式的数据

    向服务器提交的是FormData格式的数据 || 必须添加以下两个配置项 contentType:false, processData:false,

  2. python sqlite3简单操作

    python sqlite3简单操作(原创)import sqlite3class CsqliteTable: def __init__(self): pass def linkSqlite3(sel ...

  3. REST架构简介

    restful简介 在如今web开发纵横的时代,几乎处处可见web页面,每个人都有自己的设计风格,这也导致了web接口五花八门,可能一个增删改查就要对应4个不同的url,这是非常浪费资源,于是Fiel ...

  4. 模型层中QuerySet的学习

    创建对象 使用关键字参数实例化模型实例来创建一个对象,然后调用save()把它保存到数据库中 pub_obj = models.Publisher(title='奥利给出版社') pub_obj.sa ...

  5. PHP 日期与时间函数详解

    在开发过程中,我们经常碰到日期与时间戳相关的功能,今天趁此机会做个详细笔记. date_default_timezone_set('PRC'); /*把时间调到北京时间,php5默认为格林威治标准时间 ...

  6. 【原】“Error getting 'android:label' attribute”

    项目上线过程中遇到“Error getting 'android:label' attribute: attribute is not a string value”这个错误. 备忘下:是因为有act ...

  7. Mybatis入门篇之结果映射,你射准了吗?

    目录 前言 什么是结果映射? 如何映射? 别名映射 驼峰映射 配置文件开启驼峰映射 配置类中开启驼峰映射 resultMap映射 总结 高级结果映射 关联(association) 例子 关联的嵌套 ...

  8. Web最最基础

    web 网站网页一个网站是由多个网页组成的一个网页=网页元素(文字.图片.超链接.文本框.按钮.下拉框ext.) +样式+用户交互 一个网页=(网页元素)html+(样式)CSS+(用户交互)Java ...

  9. Black & White(尺取)

    链接:https://ac.nowcoder.com/acm/contest/893/F来源:牛客网 * 第一行一个整数 T ,表示接下来有 T 个样例.* 首先输入n,m,表示S串的长度n和操作次数 ...

  10. Java代理之静态代理

    什么是代理 代理就是给目标对象一个代理对象,并由代理对象控制目标的引用. 为什么要使用代理模式 1.通过引入代理对象的方式,可以间接的访问目标对象,避免直接访问目标对象给系统带来不必要的复杂性. 2. ...