11.【转】python调mysql 带输入参数的存储过程

原文:https://blog.ansheng.me/article/python-full-stack-way-mysql-stored-procedures

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

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

存储过程过接收的参数

参数描述

in仅用于传入参数用

out仅用于返回值用

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

创建存储过程

创建一个简单的存储过程

-- 修改SQL语句的结束符为%delimiter%-- 创建这个存储过程先删除DROPPROCEDUREIFEXISTSproc_p1%CREATEPROCEDUREproc_p1()-- 开始BEGIN-- SQL语句块select*fromcolor;-- 结束END%-- 把SQL语句的结束符改为;delimiter;

通过call调用存储过程

callproc_p1();

输出为

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

删除存储过程

DROPPROCEDUREproc_p1;

实例

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

delimiter%DROPPROCEDUREIFEXISTSproc_p1%createPROCEDUREproc_p1(-- i1就是传入的参数,传入的数据类型必须是int类型ini1int)BEGIN-- 定义两个局部变量d1和d2,数据类型都为int,d1默认值为空,d2默认值为1DECLAREd1int;DECLAREd2intDEFAULT1;-- d1的值等于传入过来的i1加上定义的局部变量d2的值SETd1=i1+d2;-- 查找person_info表中的nid大于d1的数据SELECT*FROMperson_infoWHEREnid>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 rowsinset(0.00 sec)Query OK, 0 rows affected(0.01 sec)

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

delimiter%DROPPROCEDUREIFEXISTSproc_p1%createPROCEDUREproc_p1(-- 接收了三个参数,类型都是intini1int,inoutiiint,outi2int)BEGIN-- 定义一个局部变量d2,默认值是3,数据类型为intDECLAREd2intDEFAULT3;-- ii = ii + 1setii=ii+1;-- 如果传入的i1等于1IFi1=1THEN-- i2 = 100 + d2seti2=100+d2;-- 如果传入的i1等于2ELSEIFi1=2THEN-- i2 = 200 + d2seti2=200+d2;-- 否则ELSE-- i2 = 1000 + d2seti2=1000+d2;ENDIF;END%delimiter;

查看数据

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

显示的结果

+------+------+| @o  | @u  |+------+------+|    6 |  103 |+------+------+1 rowinset(0.00 sec)

使用pymysql模块操作存储过程

Python代码为:

importpymysqlconn=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 withexitcode 0

存储过程使用into

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

delimiter%DROPPROCEDUREIFEXISTSproc_p2%CREATEPROCEDUREproc_p2()BEGIN-- 定义一个局部变量n,类型为intDECLAREnint;-- 获取color_nid = 2的数据并赋值给nSELECTcolor_nidintonFROMperson_infowherecolor_nid=2;-- 输出nid = n的数据SELECT*fromcolorWHEREnid=n;END%delimiter;

执行

call proc_p2();

结果

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,607评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,047评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,496评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,405评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,400评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,479评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,883评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,535评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,743评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,544评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,612评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,309评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,881评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,891评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,136评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,783评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,316评论 2 342

推荐阅读更多精彩内容