我在MySQL数据库中有一个存储过程,它只更新日期列并返回前一个日期。如果我从MySQL客户端调用这个存储过程,它可以正常工作,但是当我尝试使用MySQLdb从Python调用存储过程时,我似乎无法让它给我返回值。使用MySQLdb从Python获取MySQL存储过程的返回值
下面的代码到存储过程:
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)
我知道你能做到IN和OUT参数,但是从我可以从MySQLdb文档中确定的内容来看,这对于MySQLdb来说是不可能的。有没有人有任何线索我怎么能得到存储过程的结果?
如果我从SQL工具运行它,这里的输出:
POLL_DATE_TIME
-------------------
2009-02-18 22:27:07
如果我运行Python脚本,它返回一个空集,这样的:
()
如何在这种情况下将参数传递给游标 – sandeep 2014-10-30 08:52:40