给定一个 Wordpress 4.0 的 MySQL 数据库。我在数据库上运行以下查询:
conn = pymysql.connect(host='localhost', port=3306, user='root', passwd='geheim', db='mysite')
cur = conn.cursor()
cur1 = conn.cursor()
cur.execute("select table_name,column_name from information_schema.columns where table_schema = 'mysite' order by table_name,ordinal_position")
tables=Set()
columns=Set()
for r in cur.fetchall():
cur1.execute("select " + r[1] + " from " + r[0] )
for s in cur1.fetchall():
print r[0],r[1],s
tables.add(r[0])
columns.add(r[1])
print tables
for t in tables:
print t # to find out in which table the request crashes
cur1.execute("SELECT table_name,column_name FROM information_schema WHERE table_name='\" + `t` + \"'\"")
for r in cur1.fetchall():
print r
当我在 ipython 笔记本中运行此代码(但也作为 DOS 命令行上的 python file.py )时,我在请求结束时收到一个错误:
wp_usermeta <<<<<<<<<<<<<<<<<<<<< this seems to be the table in which the error
is occuring.
---------------------------------------------------------------------------
ProgrammingError Traceback (most recent call last)
<ipython-input-42-bcb10f00a985> in <module>()
32 for t in tables:
33 print t
---> 34 cur1.execute("SELECT table_name,column_name FROM information_schema WHERE table_name='\" + `t` + \"'\"")
35 for r in cur1.fetchall():
36 print r
C:\Users\me\Anaconda\lib\site-packages\pymysql\cursors.pyc in execute(self, query, args)
130 query = query % self._escape_args(args, conn)
131
--> 132 result = self._query(query)
133 self._executed = query
134 return result
C:\Users\me\Anaconda\lib\site-packages\pymysql\cursors.pyc in _query(self, q)
269 conn = self._get_db()
270 self._last_executed = q
--> 271 conn.query(q)
272 self._do_get_result()
273 return self.rowcount
C:\Users\me\Anaconda\lib\site-packages\pymysql\connections.pyc in query(self, sql, unbuffered)
724 sql = sql.encode(self.encoding)
725 self._execute_command(COM_QUERY, sql)
--> 726 self._affected_rows = self._read_query_result(unbuffered=unbuffered)
727 return self._affected_rows
728
C:\Users\me\Anaconda\lib\site-packages\pymysql\connections.pyc in _read_query_result(self, unbuffered)
859 else:
860 result = MySQLResult(self)
--> 861 result.read()
862 self._result = result
863 if result.server_status is not None:
C:\Users\me\Anaconda\lib\site-packages\pymysql\connections.pyc in read(self)
1062 def read(self):
1063 try:
-> 1064 first_packet = self.connection._read_packet()
1065
1066 # TODO: use classes for different packet types?
C:\Users\me\Anaconda\lib\site-packages\pymysql\connections.pyc in _read_packet(self, packet_type)
824 """
825 packet = packet_type(self)
--> 826 packet.check_error()
827 return packet
828
C:\Users\me\Anaconda\lib\site-packages\pymysql\connections.pyc in check_error(self)
368 errno = unpack_uint16(self.read(2))
369 if DEBUG: print("errno =", errno)
--> 370 raise_mysql_exception(self._data)
371
372 def dump(self):
C:\Users\me\Anaconda\lib\site-packages\pymysql\err.pyc in raise_mysql_exception(data)
114 def raise_mysql_exception(data):
115 errinfo = _get_error_info(data)
--> 116 _check_mysql_exception(errinfo)
C:\Users\me\Anaconda\lib\site-packages\pymysql\err.pyc in _check_mysql_exception(errinfo)
107 errorclass = error_map.get(errno, None)
108 if errorclass:
--> 109 raise errorclass(errno,errorvalue)
110
111 # couldn't find the right error number
ProgrammingError: (1064, u'You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near \'"\' at line 1')
我没有看到为什么请求应该在此时退出的明显原因。当我稍微更改输出量时,该命令会在其他表中退出。此时输出已达到约 800KB 和约 11000 行。
这可能是一个大规模的问题。pymysql 中的错误?我可以编写一个 MySQL 函数并尝试直接在 mysql 中执行它,但我不擅长编写 MySQL 函数或过程。有人可以让我开始吗?谢谢。