python获取数据库的存储过程_使用MySQLdb从Python中的MySQL存储过程获取返回值

我在MySQL数据库中有一个存储过程,它只更新一个日期列并返回上一个日期。如果我从MySQL客户机调用这个存储过程,它可以正常工作,但是当我试图使用MySQLdb从Python调用该存储过程时,我似乎无法让它给我返回值。

下面是存储过程的代码:CREATE PROCEDURE test_stuff.get_lastpoll()

BEGIN

DECLARE POLLTIME TIMESTAMP DEFAULT NULL;

START TRANSACTION;

SELECT poll_date_time

FROM test_stuff.poll_table

LIMIT 1

INTO POLLTIME

FOR UPDATE;

IF POLLTIME IS NULL THEN

INSERT INTO

test_stuff.poll_table

(poll_date_time)

VALUES

( UTC_TIMESTAMP() );

COMMIT;

SELECT NULL as POLL_DATE_TIME;

ELSE

UPDATE test_stuff.poll_table SET poll_date_time = UTC_TIMESTAMP();

COMMIT;

SELECT DATE_FORMAT(POLLTIME, '%Y-%m-%d %H:%i:%s') as POLL_DATE_TIME;

END IF;

END

我用来调用存储过程的代码类似于:#!/usr/bin/python

import sys

import MySQLdb

try:

mysql = MySQLdb.connect(user=User,passwd=Passwd,db="test_stuff")

mysql_cursor = mysql.cursor()

results=mysql_cursor.callproc( "get_lastpoll", () )

print results

mysql_cursor.close()

mysql.close()

except MySQLdb.Error, e:

print "MySQL Error %d: %s" % ( e.args[0], e.args[1] )

sys.exit(1)

我知道您可以输入和输出参数,但是根据MySQLdb文档中的判断,MySQLdb不可能做到这一点。有人知道我如何得到存储过程的结果吗?

如果我从一个SQL工具运行它,那么输出如下:POLL_DATE_TIME

-------------------

2009-02-18 22:27:07

如果我运行Python脚本,它将返回一个空集,如下所示:()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值