iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >6Python全栈之路系列之MySQL存储过程
  • 801
分享到

6Python全栈之路系列之MySQL存储过程

2024-04-02 19:04:59 801人浏览 泡泡鱼
摘要

python全栈之路系列之Mysql存储过程存储过程是一个sql语句集合,当主动去调用存储过程时,其中内部的SQL语句会按照逻辑执行。存储过程过接收的参数参数描述in仅用于传入参数用out仅用于返回值用in

python全栈之路系列之Mysql存储过程


存储过程是一个sql语句集合,当主动去调用存储过程时,其中内部的SQL语句会按照逻辑执行。

存储过程过接收的参数

参数描述
in仅用于传入参数用
out仅用于返回值用
inout既可以传入又可以当作返回值

创建存储过程

创建一个简单的存储过程

-- 修改SQL语句的结束符为%
delimiter %
-- 创建这个存储过程先删除
DROP PROCEDURE IF EXISTS proc_p1 %
CREATE PROCEDURE proc_p1()
-- 开始
BEGIN
    -- SQL语句块
    select * from color;
-- 结束
END %
-- 把SQL语句的结束符改为;
delimiter ;

通过call调用存储过程

call proc_p1();

输出为

+-----+--------+
| nid | title  |
+-----+--------+
|   1 | red    |
|   2 | yellow |
+-----+--------+
2 rows in set (0.00 sec)
Query OK, 0 rows affected (0.01 sec)

删除存储过程

DROP PROCEDURE proc_p1;

实例

创建一个存储过程,接收一个参数,传入的参数就是显示数据的个数,

delimiter %
DROP PROCEDURE IF EXISTS proc_p1 %
create PROCEDURE proc_p1(
    -- i1就是传入的参数,传入的数据类型必须是int类型
    in i1 int
)
BEGIN
    -- 定义两个局部变量d1和d2,数据类型都为int,d1默认值为空,d2默认值为1
    DECLARE d1 int;
    DECLARE d2 int DEFAULT 1;
    -- d1的值等于传入过来的i1加上定义的局部变量d2的值
    SET d1 = i1 + d2;
    -- 查找person_info表中的nid大于d1的数据
    SELECT * FROM person_info WHERE nid > d1;
END %
delimiter ;

查询,括号内输入定义的参数

CALL proc_p1(4);

显示结果

+-----+------+------------------+-------------+----------+----------+---------+-----------+
| nid | name | email            | phone       | part_nid | position | caption | color_nid |
+-----+------+------------------+-------------+----------+----------+---------+-----------+
|   6 | w    | as@anshengme.com | 13800138000 |        5 | Python   | NULL    |      NULL |
|   9 | aa   | a@ansheng.me     | 13800138000 |        3 | DBA      | NULL    |         2 |
|  10 | b    | b.ansheng.me     | 13800138000 |        3 | DBA      | NULL    |         1 |
+-----+------+------------------+-------------+----------+----------+---------+-----------+
3 rows in set (0.00 sec)

Query OK, 0 rows affected (0.01 sec)

这次把nid大于5的数据全部输出出来了,传入的值是4,我们在内部让4+1了,所以就是大于5的数据.

delimiter %
DROP PROCEDURE IF EXISTS proc_p1 %
create PROCEDURE proc_p1(
    -- 接收了三个参数,类型都是int
    in i1 int,
    inout ii int,
    out i2 int
)
BEGIN
    -- 定义一个局部变量d2,默认值是3,数据类型为int
    DECLARE d2 int DEFAULT 3;
    -- ii = ii + 1
    set ii = ii + 1;
    -- 如果传入的i1等于1
    IF i1 = 1 THEN
        -- i2 = 100 + d2
        set i2 = 100 + d2;
    -- 如果传入的i1等于2
    ELSEIF i1 = 2 THEN
        -- i2 = 200 + d2
        set i2 = 200 + d2;
    -- 否则
    ELSE
        -- i2 = 1000 + d2
        set i2 = 1000 + d2;
    END IF;
END %
delimiter ;

查看数据

set @o = 5;
CALL proc_p1(1,@o,@u);
SELECT @o,@u;

显示的结果

+------+------+
| @o   | @u   |
+------+------+
|    6 |  103 |
+------+------+
1 row in set (0.00 sec)

使用pymysql模块操作存储过程

Python代码为:

import pymysql

conn = pymysql.connect(host="127.0.0.1", port=3306, user='root', passwd='as', db="dbname")
cursor = conn.cursor(cursor=pymysql.cursors.DictCursor)

# 执行存储过程
row = cursor.callproc("proc_p2",(1,2,3))
# 存储过程的查询结果
selc = cursor.fetchall()
print(selc)
# 获取存储过程返回
effect_row = cursor.execute('select @_proc_p2_0, @_proc_p2_1, @_proc_p2_2')
# 取存储过程返回值
result = cursor.fetchone()
print(result)

conn.commit()
cursor.close()
conn.close()

显示的结果

C:\Python\python35\python.exe D:/PyCharmProjects/pymysql_存储过程.py
[{'nid': 1, 'name': 'man1'}, {'nid': 2, 'name': 'man2'}, {'nid': 3, 'name': 'man3'}]
{'@_proc_p2_1': 3, '@_proc_p2_0': 1, '@_proc_p2_2': 103}

Process finished with exit code 0

存储过程使用into

into其实就是把一个select的执行结果当作另一个select的参数,例如下面的实例:

delimiter %
DROP PROCEDURE IF EXISTS proc_p2 %
CREATE PROCEDURE proc_p2()
BEGIN
    -- 定义一个局部变量n,类型为int
    DECLARE n int;
    -- 获取color_nid = 2的数据并赋值给n
    SELECT color_nid into n FROM person_info where color_nid = 2;
    -- 输出nid = n的数据
    SELECT * from color WHERE nid = n;
END %
delimiter ;

执行

call proc_p2();

结果

+-----+--------+
| nid | title  |
+-----+--------+
|   2 | yellow |
+-----+--------+
1 row in set (0.00 sec)

Query OK, 0 rows affected (0.01 sec)


#Python全栈之路

您可能感兴趣的文档:

--结束END--

本文标题: 6Python全栈之路系列之MySQL存储过程

本文链接: https://www.lsjlt.com/news/38888.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 6Python全栈之路系列之MySQL存储过程
    Python全栈之路系列之MySQL存储过程存储过程是一个SQL语句集合,当主动去调用存储过程时,其中内部的SQL语句会按照逻辑执行。存储过程过接收的参数参数描述in仅用于传入参数用out仅用于返回值用in...
    99+
    2022-10-18
  • 3Python全栈之路系列之MySQL表
    先创创建一个表用于测试-- 创建数据库 CREATE DATABASE dbname DEFAULT CHARSET utf8 COLLATE utf8_general_ci; -- 创建表 CREATE TABLE `tb` (   `i...
    99+
    2023-01-31
    之路 系列之 Python
  • 8Python全栈之路系列之MySQL触发器
    Python全栈之路系列之MySQL触发器l对某个表进行增/删/改操作的前后如果希望触发某个特定的行为时,可以使用触发器,触发器用于定制用户对表的行进行增/删/改前后的行为。创建触发器基本语法插入前CREA...
    99+
    2022-10-18
  • 2Python全栈之路系列之SQLAchemy
    Python全栈之路系列之SQLAlchemySQLAlchemy的是Python SQL工具包和对象关系映射器,让应用程序开发者的全部功能和SQL的灵活性。它提供了一套完整的众所周知的企业级持久性模式,专...
    99+
    2022-10-18
  • Python全栈之路系列之Python
    The Python interpreter has a number of functions and types built into it that are always available. They are listed her...
    99+
    2023-01-31
    之路 系列之 Python
  • 3Python全栈之路系列之D
    模板是一个文本,用于分离文档的表现形式和内容,模板定义了占位符以及各种用于规范文档该如何显示的各部分基本逻辑(模板标签)。模板通常用于产生HTML,但是Django的模板也能产生任何基于文本格式的文档。如何使用模板系统在Python代码中使...
    99+
    2023-01-31
    之路 系列之 Python
  • 3Python全栈之路系列之Rabbit
    RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件。RabbitMQ服务器是用Erlang语言编写的,它可以为你的应用提供一个通用的消息发送和接收平台,并且保证消息在传输过程中的安全,RabbitMQ官网,RabbitM...
    99+
    2023-01-31
    之路 系列之 Python
  • 3Python全栈之路系列之MySQL表内操作
    Python全栈之路系列之MySQL表内操作先创创建一个表用于测试-- 创建数据库 CREATE DATABASE dbname DEFAULT CHARS...
    99+
    2022-10-18
  • 4Python全栈之路系列之Django模型
    Python全栈之路系列之Django模型MTV开发模式把数据存取逻辑、业务逻辑和表现逻辑组合在一起的概念有时被称为软件架构的Model-View-Controller(MVC)模式。在这个模式中,Mode...
    99+
    2022-10-18
  • 3Python全栈之路系列之基于sock
    发布时间:2017年3月16日 00:04 浏览(106) 评论(0) 分类:Python前言此处没有前言粘包在实现发送文件功能之前我们先来理解下粘包的问题,下面有两张图,我觉得很清晰的就可以理解到了。正常情况下发送文件第一步: 客户端把获...
    99+
    2023-01-31
    之路 系列之 Python
  • 2Python全栈之路系列之MysQl基本数据类型
    Python全栈之路系列之MySQL基本数据类型MySQL中定义数据字段的类型对你数据库的优化是非常重要的。MySQL支持多种类型,大致可以分为三类:数字类型日期和时间类型字符串类型数字类型类型大小用途BI...
    99+
    2022-10-18
  • Python全栈之路系列之文件操作
    Python可以对文件进行查看、创建等功能,可以对文件内容进行添加、修改、删除,且所使用到的函数在Python3.5.x为open,在Python2.7.x同时支持file和open,但是在3.5.x系列移除了file函数。 Python...
    99+
    2023-01-31
    之路 操作 文件
  • Python全栈之路系列之字符串格式化
    This PEP proposes a new system for built-in string formatting operations, intended as a replacement for the existing '%...
    99+
    2023-01-31
    之路 字符串 系列之
  • 3Python全栈之路系列之字符串数据类
    字符串(str)字符串类型是python的序列类型,他的本质就是字符序列,而且python的字符串类型是不可以改变的,你无法将原字符串进行修改,但是可以将字符串的一部分复制到新的字符串中,来达到相同的修改效果。创建字符串类型可以使用单引号或...
    99+
    2023-01-31
    之路 字符串 数据
  • Python全栈之路系列之字符串数据类
    字符串(str) 字符串类型是python的序列类型,他的本质就是字符序列,而且python的字符串类型是不可以改变的,你无法将原字符串进行修改,但是可以将字符串的一部分复制到新的字符串中,来达到相同的修改效果。 创建字符串类型可以使用单...
    99+
    2023-01-31
    之路 字符串 数据
  • MySQL之存储过程
    我的小站:我的博客 1.1 存储过程简介 存储过程是一组为了完成特定功能的SQL语句集合,经编译后存储在数据库中。用户通过指定存储过程的名字并给出参数的值 MySQL 5.0 版本开始支持存储过程。 存储过程(Stored Procedur...
    99+
    2023-09-02
    数据库 mysql sql
  • 7Python全站之路系列之MySQL视图
    Python全栈之路系列之MySQL视图视图是一个虚拟表(非真实存在),其本质是根据SQL语句获取动态的数据集,并为其命名,用户使用时只需使用名称即可获取结果集,并可以将其当作表来使用。创建视图创建一个名称...
    99+
    2022-10-18
  • MySQL系列之五 视图、存储函数、存储过程、触发器
    目录系列教程一、视图 1、视图的创建 2、查看视图定义 3、删除视图 二、存储函数 1、系统函数 2、自定义函数(user-defined function:UDF) 三、存储过程 ...
    99+
    2022-11-12
  • 9Python全站之路系列之MySQL SL注入
    Python全栈之路系列之MySQL SQL注入SQL注入是一种代码注入技术,过去常常用于***数据驱动性的应用,比如将恶意的SQL代码注入到特定字段用于实施******等。SQL注入的成功必须借助应用程序...
    99+
    2022-10-18
  • MySQL系列之七 MySQL存储引擎
    一、MyISAM存储引擎 缺点: 不支持事务 最小粒度锁:表级 读写相互阻塞,写入不能读,读时不能写 不支持MVCC(支持多版本并发控制机制) ...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作