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

为Django配置mysql驱动::macOS

  • 目的
  • 更改project的settings.py
  • 安装mysql-connector-c
  • 安装mysql驱动:mysqlclient
  • 错误
  • 更多资源

目的

为了建立自己的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个错误:
为Django配置mysql驱动(macOS环境下)_第1张图片
仔细读取错误信息发现问题在于 clang编译器没有找到ssl库ld:library not found for -lssl

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

%brew info openssl

便可得到下列信息
为Django配置mysql驱动(macOS环境下)_第2张图片

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

%pip install mysqlclient

恭喜!!安装成功!

更多资源

  • export等关于bash的简短文章

你可能感兴趣的:(为Django配置mysql驱动(macOS环境下))