0、创建表:

(1)建表:

CREATE TABLE blog (

id INT PRIMARY KEY auto_increment,

name CHAR(64),

sub_time datetime

);

(2)查看数据(为空):

1、什么是存储过程:

(1)存储过程包含了一系列可执行的sql语句,存储过程存放于MySQL中,通过调用它的名字

可以执行其内部的一堆sql。

(2)使用存储过程的优点:

1)用于替代程序写的SQL语句,实现程序与sql解耦。

2)基于网络传输,传别名的数据量小,而直接传sql数据量大。

(3)使用存储过程的缺点:

1)程序员扩展功能不方便。

(4)补充:程序与数据库结合使用的三种方式:

1)方式一:

MySQL:存储过程

程序:调用存储过程

2)方式二:

MySQL:

程序:纯SQL语句

3)方式三:

MySQL:

程序:类和对象,即ORM(本质还是纯SQL语句)

2、创建简单存储过程(无参):

(1)代码:

delimiter //

create procedure p1()

BEGIN

select * from blog;

INSERT into blog(name,sub_time) values("xxx",now());

END //

delimiter ;

(2)在mysql中调用:

1)调用存储过程:

call p1();

2)查看数据(数据已经被插入):

(3)在python中基于pymysql调用:

cursor.callproc('p1')

print(cursor.fetchall())

3、创建存储过程(有参):

(1)参数说明:

对于存储过程,可以接收参数,其参数有三类:

1)in #仅用于传入参数用

2)out #仅用于返回值用

3)inout #既可以传入又可以当作返回值

(2)in:传入参数:

1)代码:

delimiter //

create procedure p2(

in n1 int,

in n2 int

/*定义输入值的类型*/

)

BEGIN

select * from blog where id > n1;

END //

delimiter ;

2)在mysql中调用存储过程:

call p2(0,2);

3)在python中基于pymysql调用:

cursor.callproc('p2',(3,2))

print(cursor.fetchall())

(3)out:返回值:

1)代码:

delimiter //

create procedure p3(

in n1 int,

out res int

)

BEGIN

select * from blog where id > n1;

set res = 1;

END //

delimiter ;

2)在mysql中调用存储过程:

--设置会话级变量:

set @res=0;

#0代表假(执行失败),1代表真(执行成功)

--查询:

--调用存储过程:

call p3(0,@res);

--查询:

--说明:需要设置会话级变量,out返回的结果再赋给会话级变量。

3)在python中基于pymysql调用:

cursor.callproc('p3',(3,0))

#0相当于set @res=0

print(cursor.fetchall())

#查询select的查询结果

cursor.execute('select @_p3_0,@_p3_1;')

#@p3_0代表第一个参数,@p3_1代表第二个参数,即返回值

print(cursor.fetchall())

(4)inout:既可以传入值又可以返回值:

1)代码:

delimiter //

create procedure p4(

inout n1 int

)

BEGIN

select * from blog where id > n1;

set n1 = 1;

END //

delimiter ;

2)在mysql中调用存储过程:

--设置会话级变量:

set @x=0;

--查询:

--调用存储过程:

call p4(@x);

--查询:

select @x;

--说明:需要设置会话级变量,inout返回的结果再赋给会话级变量。

3)在python中基于pymysql调用:

cursor.callproc('p4',(3,))

print(cursor.fetchall())

#查询select的查询结果

cursor.execute('select @_p4_0;')

print(cursor.fetchall())

4、执行存储过程:

(1)无参数:

call proc_name()

(2)有参数,全in:

call proc_name(1,2)

(3) 有参数,有in,out,inout:

set @t1=0;

set @t2=3;

call proc_name(1,2,@t1,@t2)

--说明:需要设置会话级变量,inout或out返回的结果再赋给会话级变量。

5、删除存储过程:

(1)语法:

drop procedure 存储过程名称

(2)示例:

drop procedure p1;

drop procedure p2;

drop procedure p3;

drop procedure p4;

6、存储过程之流程控制:

(1)if条件语句:

1)代码:

delimiter //

CREATE PROCEDURE proc_if (

in i int

/*定义输入值的类型*/

)

BEGIN

/*declare i int default 0;*/

/*在存储过程主体中定义变量类型及默认值*/

if i = 1 THEN

SELECT 1;

/*输出结果*/

ELSEIF i = 2 THEN

SELECT 2;

ELSE

SELECT 7;

END IF;

END //

delimiter ;

2)示例:

call proc_if(9);

call proc_if(2);

(2)while循环语句:

1)代码:

delimiter //

CREATE PROCEDURE proc_while ()

BEGIN

DECLARE num INT;

SET num = 0;

WHILE num < 3 DO

SELECT num;

SET num = num + 1;

END WHILE;

END //

delimiter ;

2)示例:

call proc_while();

(3)repeat循环语句:

1)代码:

delimiter //

CREATE PROCEDURE proc_repeat()

BEGIN

DECLARE i INT;

SET i = 0;

repeat

select i;

set i = i + 1;

until i >= 3

end repeat;

END //

delimiter ;

2)示例:

41、mysql数据库(存储过程)的更多相关文章

  1. JDBC对MySQL数据库存储过程的调用

    一.MySQL数据库存储过程: 1.什么是存储过程 存储过程(英文:Stored Procedure)是在大型数据库系统中,为了完成特定功能而编写的一组的SQL语句集.存储过程经编译存储在数据库中,用 ...

  2. MySQL数据库----存储过程

    存储过程 存储过程包含了一系列可执行的sql语句,存储过程存放于MySQL中,通过调用它的名字可以执行其内部的一堆sql -- 存储过程的优点: -- 1.程序与数据实现解耦 -- 2.减少网络传输的 ...

  3. 关于MySQL数据库存储过程的感想

    以下只是学习路上的浅薄感想,如理解有所偏差,还请有识之士指正! 一.存储过程意义理解 关于存储过程,我的理解是对数据库语言进行编程调用,就像Java代码类编程写一个具有某种特定功能的方法去进行调用一样 ...

  4. mysql数据库存储过程异常处理

    14.1.4  定义条件和处理程序 定义条件和处理程序是事先定义程序执行过程中可能遇到的问题.并且可以在处理程序中定义解决这些问题的办法.这种方式可以提前预测可能出现的问题, 并提出解决办法.这样可以 ...

  5. MySQL数据库存储过程动态表建立(PREPARE)

    PREPARE statement_name FROM sql_text /*定义*/ EXECUTE statement_name [USING variable [,variable...]] / ...

  6. MySQL数据库中delimiter的作用概述

    以下的文章主要是向大家描述的是MySQL数据库中delimiter的作用是什么?我们一般都认为这个命令和存储过程关系不大,到底是不是这样的呢?以下的文章将会给你相关的知识,望你会有所收获. 其实就是告 ...

  7. mysql之——存储过程 + 游标 + 事务

    下面是自己曾经编写过的mysql数据库存储过程,留作存档,以后用到的时候拿来参考. 其中,涉及到了存储过程.游标(双层循环).事务. [说明]:代码中的注释只针对当时业务而言,无须理会. 代码如下: ...

  8. ava基础MySQL存储过程 Java基础 JDBC连接MySQL数据库

    1.MySQL存储过程   1.1.什么是存储过程 带有逻辑的sql语句:带有流程控制语句(if  while)等等 的sql语句   1.2.存储过程的特点 1)执行效率非常快,存储过程是数据库的服 ...

  9. Mysql 数据库无法删除 41 错误

    今天删除Mysql 数据库时候,没法删除,直接报错 41: 方法,进入 mysql的安装目录 我的是:D:\tools\Mysql\V76384-01\mysql-advanced-5.6.25-wi ...

随机推荐

  1. IT菜鸟之总结(Du teacher)

    初次接触云计算,从以前对计算机的一窍不通,经过这三周的学习,起码是通了一窍了:哈哈,至少是对计算机的组成及系统的安装都有了认识,也初次学习了Linux系统,对其的发展和使用有了认识,也学到了一些基础的 ...

  2. Java 中 volatile 关键字及其作用

    引言 作为 Java 初学者,几乎从未使用过 volatile 关键字.但是,在面试过程中,volatile 关键字以及其作用还是经常被面试官问及.这里给各位童靴讲解一下 volatile 关键字的作 ...

  3. git push 时发生错误 error: src refspec master does not match any. error: failed to push some refs to

    很多相关解决办法都是最后要 push 到远端的 master 上,但很多其实要求不能把个人的修改内容直接 push 到 master 主分支. 因此,当我想将本地 feature/work1 分支的修 ...

  4. Go语言web开发---Beego的session

    一.简介 Session是一段保存在服务器上的信息,当客户端第一次访问服务器时创建Session,同时也会创建一个名为beegosessionID,值为创建的Session的id的Cookie. 这个 ...

  5. Python+Selenium学习笔记17 - HTML测试报告

    运行少量case时 1 # coding = utf-8 2 3 from selenium import webdriver 4 import unittest 5 import time 6 fr ...

  6. win系统下如何安装xgboost,开发环境是anaconda,以及这中间需要注意的问题

    最近学到了xgboost,但是anaconda并没有这个环境只好自己安装了... 注: (1)并没有测试anaconda在2.x的版本下是如何安装的, 基本上应该是大同小类的,我的anaconda版本 ...

  7. 论文阅读:MDNet: Learning Multi-Domain Convolutional Neural Networks for Visual Tracking

    前言 CVPR2016 来自Korea的POSTECH这个团队   大部分算法(例如HCF, DeepLMCF)只是用在大量数据上训练好的(pretrain)的一些网络如VGG作为特征提取器,这些做法 ...

  8. 用命令行开启关闭windows系统服务

    #删除服务 sc delete servicename   #启动服务 sc start servicename   #停止服务 sc stop servicename   #查询所有服务的状态 sc ...

  9. 3D点云深度学*

    3D点云深度学* 在自动驾驶中关于三维点云的深度学*方法应用.三维场景语义理解的方法以及对应的关键技术介绍. 1. 数据 但是对于3D点云,数据正在迅速增长.大有从2D向3D发展的趋势,比如在open ...

  10. 如何在CPU上优化GEMM(上)

    如何在CPU上优化GEMM(上) (TL:DR)TVM提供了抽象接口,用户分别描述算法和算法的实现组织(所谓的调度).通常,在高性能调度中编写算法会破坏算法的可读性和模块性.尝试各种看似有希望的时间表 ...