在Python DB API中使用存储过程

在Python DB API中使用存储过程

Python的DB API是包含存储过程支持的,在Cursor对象的.callproc方法上实现。不过很可惜,我们所知的大部分Python DB API都没有实现这个方法。(by gashero)一部分原因是数据库本身不支持,亦或是驱动不支持。这些例子包括pysqlite2,这个是典型的数据库不支持。odbc,这个么,就是没有实现了。pymssql,这个也是没有实现的。

而实际上有些时候还是很有必要调用存储过程的,(by gashero)比如历史代码的复用等等。所以我们可以避开实现上的问题,而直接用SQL实现存储过程调用,让Python重新支持存储过程。下面的例子使用pymssql连接了远程的MS SQL 2000。示例代码如下:

import pymssql
conn=pymssql.connect(host="192.168.0.1",user="sa",password="***",/
    database="***")
cur=conn.cursor()
cur.execute("exec sp_name @param1=%s",('hello',))
data=cur.fetchall()
print data

这里的存储过程名为sp_name,并只含有一个参数param1,(by gashero)对其赋值的过程为%s,并在后面的元组中给出。这里应该注意所需参数的类型,如果参数要求是整数类型,也应该灵活的将其修改为%d,然后在后面的元组中给出对应整数值。
共勉。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值