在进行django学习过程中,尝试使用框架连接mysql数据库,启动服务器的时候经常遇到Error loading MySQLdb module: No module named 'MySQLdb'
这个错误到处去查也没有解决。最后闹明白了。
发生这个错误是因为django框架如果连接mysql需要用到MySQLdb包。
这个包用pip install MySQLdb 是找不到的。正确的解决办法如下:
第一步 找到django项目的settings.py将数据库部分设置成
DATABASES = {
"default"{
"ENGINE": "django.db.backends.mysql",
"NAME":"数据库名",
"USER": "mysql数据库用户名",
"PASSWORD":"mysql的密码",
"HOST":"数据库所在的id",
"PORT":"" #mysql的端口
}
}
注意 NAME 的值指定要使用mysql下某个数据库,,需要提前进入mysql创建一个该名称的数据库
第二步 为django导入连接mysql的必要模块 在python2 和python3 环境下需要不同的设置
在python2中:
在django项目的运行环境中安装mysql-python模块
终端执行:
pip install mysql-python
在python3中:
pip install pymysql
在项目里的__init__.py文件中中加入以下代码:
import pymysql
pymysql.install_as_MySQLdb()
表示引入pymysql模块,然后借助pymysql引入MySQLdb
之后启动服务器,应该就解决了问题,不会再发生上述问题。
启动服务器:
python manage.py runserver