我正在尝试使用MySQL连接器作为pymysql的替代方法,因为它在一个查询中支持多个语句,我必须进行一些更新(Here is my other question related to that)但是我的其他用例非常失败大选择陈述。
我有一个动态生成的Select语句,它检索与传入的任何指定值匹配的所有行;例如Select * from table where col_a in (val_1, val_2.... val_350,000)
我的select语句一直出现同样的错误:
Exception in thread Thread-1:
Traceback (most recent call last):
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/mysql/connector/network.py", line 212, in send_compressed
self.sock.sendall(zip_packet)
BlockingIOError: [Errno 35] Resource temporarily unavailable
During handling of the above exception, another exception occurred:
Traceback (most recent call last):
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/threading.py", line 921, in _bootstrap_inner
self.run()
File "/Users/maldeiri/raw_data_processing/sql_retriever.py", line 22, in run
self.mysql_cursor.execute(self.sql_statement)
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/mysql/connector/cursor.py", line 515, in execute
self._handle_result(self._connection.cmd_query(stmt))
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/mysql/connector/connection.py", line 488, in cmd_query
result = self._handle_result(self._send_cmd(ServerCmd.QUERY, query))
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/mysql/connector/connection.py", line 261, in _send_cmd
packet_number)
File "/Library/Frameworks/Python.framework/Versions/3.4/lib/python3.4/site-packages/mysql/connector/network.py", line 215, in send_compressed
errno=2055, values=(self.get_address(), _strioerror(err)))
mysql.connector.errors.OperationalError: 2055: Lost connection to MySQL server at 'database_end_point:3306', system error: 35 Resource temporarily unavailable
无论我有compress = True还是False,都会发生这种情况。我也不认为这是服务器端问题,因为我提到完全相同的Select语句似乎与pymysql运行相同的代码和机器。
我有什么想法可以解决这个问题?
答案 0 :(得分:3)
不要构建那个可怕的IN(...)
,而是将值抛出到一个表中,每行一个。
然后对真实表执行JOIN
以获取所需的行。 (确保col_a
已在真实表格中编入索引;请勿在额外表格中对其进行索引。)
如果巨大的列表可以有重复,您应该首先删除列表。看看Python是否可以轻松完成。如果没有,您可以在插入它们时将该一列设为PRIMARY KEY
并执行INSERT IGNORE
。或者,
CREATE TABLE t (val) ENGINE=MyISAM;
INSERT or LOAD DATA ... (no dedupping)
SELECT rt.* FROM real_table
JOIN ( SELECT DISTINCT val FROM t ) ON rt.val = t.val;