Python の MySQLdb を使う時に symbol not found in flat namespace '_mysql_affected_rows' が出た場合の対応

Django Python
2023-11-09 12:39 (6ヶ月前) ytyng

Apple silicon の Python で MySQL を操作しようとして

ImportError: dlopen(/.../site-packages/MySQLdb/_mysql.cpython-310-darwin.so, 0x0002): symbol not found in flat namespace '_mysql_affected_rows'

が出た。

Macos M1 mysqlclient Symbol not found: _mysql_affected_rows ERROR · Issue #496 · PyMySQL/mysqlclient

上記のコメントを参考にする。

私の環境では

% echo $MYSQLCLIENT_LDFLAGS
-L/opt/homebrew/opt/openssl/lib -L/opt/homebrew/opt/mysql/lib -L/opt/homebrew/opt/zlib/lib -L/opt/homebrew/lib

となっていたので、

% echo $MYSQLCLIENT_LDFLAGS
-L/opt/homebrew/opt/openssl/lib -L/opt/homebrew/opt/mysql/lib -L/opt/homebrew/opt/zlib/lib -L/opt/homebrew/lib -lmysqlclient -rpath /opt/homebrew/opt/mysql/lib

となるように修正した。

その後、

pip uninstall mysqlclient
pip cache purge
pip install mysqlclient

を行った。

python3

>>> import MySQLdb
>>>

でエラーが出なければOK

Currently unrated

Comments

Archive

2024
2023
2022
2021
2020
2019
2018
2017
2016
2015
2014
2013
2012
2011