У меня есть хранимая процедура в базе данных MySQL, которая просто обновляет столбец даты и возвращает предыдущую дату. Если я вызову эту хранимую процедуру из клиента MySQL, она будет работать нормально, но когда я попытаюсь вызвать хранимую процедуру из Python с помощью MySQLdb, я не могу заставить ее вернуть мне возвращаемое значение.Получение возвращаемых значений из хранимой процедуры MySQL в Python с использованием MySQLdb
Вот код хранимой процедуры:
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