为Django配置mysql驱动(macOS环境下)

目的

为了建立自己的blog,需要数据库存储数据.当然可以使用python自带的sqlite3,但为了能够更好在网络上运行起来,我选择mysql.

更改project的settings.py

Django创建项目是默认使用python自带的sqlite3,所以我们需要做出修改.

Location:projection_root/projection_name/settings.py

Change

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': 'mydatabase',
    }
}

to

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'mydatabase',
        'USER': 'mydatabaseuser',
        'PASSWORD': 'mypassword',
        'HOST': '127.0.0.1',
        'PORT': '3036',
    }
}
  • mysql的默认端口为3036

安装mysql-connector-c

mysqlclient需要mysql-connector-c

  • 通过brew安装:
brew install mysql-connector-c
  • 注意官网上所标志的出现在macOS上的bug,我们需要更改mysql_config文件:
    这个文件是mysql-connector-c所含有的,可以通过指令获得文件位置:

    %which mysql_config

然后修改其中内容:

# on macOS, on or about line 112:
# Create options
libs="-L$pkglibdir"
libs="$libs -l "

to

# Create options
libs="-L$pkglibdir"
libs="$libs -lmysqlclient -lssl -lcrypto"

安装mysql驱动:mysqlclient

前期准备已经做好,通过PyPi下载mysqlclient

%pip install mysqlclient

恭喜你成功配置好mysql驱动

错误

总是不会如意!!
在执行 pip install mysqlclient的时候提示有8个警告,1个错误:
错误提示
仔细读取错误信息发现问题在于 clang编译器没有找到ssl库ld:library not found for -lssl

其实在mysqlclient主页,除了明确标准了需要修改mysql_config文件外,还说明另一个关于OpenSSL存在的问题.
我们输入

%brew info openssl

便可得到下列信息
在这里插入图片描述

在命令行输入上面两行命令后,再次运行

%pip install mysqlclient

恭喜!!安装成功!

更多资源

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值