安装mysql
brew install mysql@8.0
修改环境变量
vim ~/.zshrc
或者
vim ~/.bashrc
将下面的环境变量加到你的环境变量文件中。如果没有配置,安装过程中也许你会出现错误,mysql.h文件没有找到
export MYSQL_HOME=/opt/homebrew/opt/mysql@8.0
export PATH=$PATH:$MYSQL_HOME/bin
# 以下是macos系统intel系列
# export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$MYSQL_HOME/lib
# export DYLD_LIBRARY_PATH=$DYLD_LIBRARY_PATH:$MYSQL_HOME/lib
# 以下是macos系统m系列
export PKG_CONFIG_PATH=PKG_CONFIG_PATH:$MYSQL_HOME/lib/pkgconfig
export CPPFLAGS=-I$MYSQL_HOME/include
export LDFLAGS=-L$MYSQL_HOME/lib
安装mysqlclient插件
pip install mysqlclient==2.2 -i https://pypi.tuna.tsinghua.edu.cn/simple
查看mysql库引用文件是否正确
otool -L .venv/lib/python3.10/site-packages/MySQLdb/_mysql.cpython-310-darwin.so
如果显示了libmysqlclient.21.dylib就是找到了mysql库文件。如果没有找到,运行python时,可能出现异常symbol not found in flat namespace ‘_mysql_affected_rows’。按照下面的方式,先清理插件和缓存,重新安装插件即可。
.venv/lib/python3.10/site-packages/MySQLdb/_mysql.cpython-310-darwin.so:
/opt/homebrew/opt/mysql@8.0/lib/libmysqlclient.21.dylib (compatibility
version 21.0.0, current version 21.0.0) /usr/lib/libSystem.B.dylib
(compatibility version 1.0.0, current version 1351.0.0)
如果没有找到mysql库引用,需要清理旧的插件后,重新安装插件
pip cache remove mysqlclient
pip uninstall mysqlclient
友情提示
mysql8必须用mysql8的库文件libmysqlclient.21.dylib,否则会出现兼容性问题。网上有不少解决方法,要么魔改mysqlclient插件库,屏蔽判断版本的代码;要么就保证库文件版本一致。


2164

被折叠的 条评论
为什么被折叠?



