知行编程网知行编程网  2022-10-01 12:30 知行编程网 隐藏边栏  225 
文章评分 0 次,平均分 0.0
导语: 本文主要介绍了关于Python MySQL callproc方法:调用数据库存储过程的相关知识,包括存储过程有返回值,以及python怎么将数据存到数据库这些编程知识,希望对大家有参考作用。

Python MySQL callproc方法:调用数据库存储过程

MySQL 数据库模块为游标对象提供了一个非标准的 callproc(self, procname, args=()) 方法,用于调用数据库存储过程。

callproc方法的procname参数代表存储过程的名称,args参数用于为存储过程传入​​参数。

下面的 SQL 脚本可以在 MySQL 数据库中创建一个简单的存储过程。打开MySQL命令行客户端,连接python数据库,输入如下SQL脚本创建存储过程:

delimiter //
create procedure add pro(a int, b int, out sum int)
begin
set sum = a + b;
end;
//

下面程序示范了使用 MySQL 数据库模块来调用存储过程:

# 导入访问MySQL的模块
import mysql.connector

# ①、连接数据库
conn = conn = mysql.connector.connect(user='root', password='32147',
    host='localhost', port='3306',
    database='python', use_unicode=True)
# ②、获取游标
c = conn.cursor()
# ③、调用callproc()方法执行存储过程
# 虽然add_pro存储过程需要3个参数,但最后一个参数是传出参数,
# 因此程序不会用它的值
result_args = c.callproc('add_pro', (5, 6, 0))
# 返回的result_args既包含了传入参数的值,也包含了传出参数的值
print(result_args)
# 如果只想访问传出参数的值,可直接访问result_args的第3个元素,如下代码
print(result_args[2])
# ④、关闭游标
c.close()
# ⑤、关闭连接
conn.close()

上面程序中,第 13 行代码就是调用存储过程的关键代码。使用 MySQL 数据库模块调用存储过程非常简单,存储过程需要几个参数,程序通过 callproc() 方法调用存储过程时就传入一个包含几个元素的元组;对于存储过程的传入参数,该参数对应的元组元素负责为传入参数传值;对于存储过程的传出参数,该参数对应的元组元素随便定义即可。

运行上面的程序,可以看到如下输出结果:

(5, 6, 11)
11

从上面的输出可以看出,当程序使用Python调用存储过程时,程序返回了一个由传入参数和传出参数组成的元组,如第一行输出所示。如果程序只需要获取传出参数的值,可以通过返回的结果元组获取对应的值。

本文为原创文章,版权归所有,欢迎分享本文,转载请保留出处!

知行编程网
知行编程网 关注:1    粉丝:1
这个人很懒,什么都没写
扫一扫二维码分享