我寫了一個python腳本來執行我的sql腳本。當我使用源手動運行該SQL腳本它不給我任何錯誤只是警告,並充分執行爲:運行vi時sql腳本python給出錯誤
mysql> source the_actual_script.sql
Database changed
Query OK, 0 rows affected, 1 warning (0.00 sec)
Query OK, 0 rows affected, 1 warning (0.00 sec)
Query OK, 0 rows affected, 1 warning (0.00 sec)
Query OK, 0 rows affected, 1 warning (0.00 sec)
Query OK, 0 rows affected, 1 warning (0.00 sec)
Query OK, 0 rows affected (0.00 sec)
Query OK, 0 rows affected (0.29 sec)
Query OK, 0 rows affected (0.00 sec)
mysql>
但是當我嘗試,並通過我的Python代碼運行它:
import MySQLdb
db = MySQLdb.connect("aws.eu-central-1.rds.amazonaws.com","prod_user","pass","db_name")
cursor = db.cursor()
for line in open("/home/ubuntu/PATCHER/the_check_query.sql"):
print cursor.execute(line)
db.close()
它給我的錯誤:
test.py:8: Warning: PROCEDURE saas_neopostsa.temp_prod does not exist
cursor.execute(line)
test.py:8: Warning: PROCEDURE saas_neopostsa.temp_prod_neopost does not exist
cursor.execute(line)
test.py:8: Warning: PROCEDURE saas_neopostsa.temp_prod_neopostsa does not exist
cursor.execute(line)
test.py:8: Warning: Unknown table 'temp_identity_neopostsa'
cursor.execute(line)
test.py:8: Warning: Unknown table 'temp_identity'
cursor.execute(line)
Traceback (most recent call last):
File "test.py", line 8, in <module>
cursor.execute(line)
File "/usr/lib/python2.7/dist-packages/MySQLdb/cursors.py", line 174, in execute
self.errorhandler(self, exc, value)
File "/usr/lib/python2.7/dist-packages/MySQLdb/connections.py", line 36, in defaulterrorhandler
raise errorclass, errorvalue
_mysql_exceptions.OperationalError: (1065, 'Query was empty')
有人可以幫助我什麼是錯?
可能重複[在python中讀取外部sql腳本](http://stackoverflow.com/questions/19472922/reading-external-sql-script-in-python) –