最近需要做一个web项目,想来想去选择了django,这也是我在python上第一次写web项目了。既然是个项目,那必然会用到数据库,django自带的sqllite数据库感觉太小儿科,所以想换成mysql了,下面讲讲我的配置过程和踩过的坑。
环境:Python 3.6 , Django 1.9 , Mysql
在django的settings.py脚本中把sqllite的连接配置改成mysql:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': '数据库名',
'USER':'root',
'PASSWORD':'mysql密码',
'HOST':'你的mysql服务器地址',
'PORT':'',
}
}
这个连接配置没什么好说的,其中PORT如果你留空的话默认是3306端口,如果你设置了别的端口的话,可以填上去。
这时候运行程序,你会发现报错!它会提示找不到MySQLdb
我找了很久才发现MySQLdb没有python3的支持库,他们官方网站也是这么写的!然后找到了python3上可以运行的pymysql库。具体配置方法:
首先pip安装一下
pip install pymysql
然后在django的settings.py脚本中加上这两行:
import pymysql
pymysql.install_as_MySQLdb()
接下来试验一下刚配置的环境能不能运行,在models.py文件中新建一个User model:
class User(models.Model):
username = models.CharField(max_length = 30)
def __unicode__(self):
return self.username
然后让django为我们自动同步这个model,也就是说django在mysql自动创建User model对应的表:
这里有个坑!(如果你用1.6以下版本的django的话你可以用manage.py syncdb命令,如果你用了1.6以上版本的话你得用 manage.py migrate命令)
manage.py migrate
控制台显示创建user表
就这样配置完了,接下来可以愉快码代码了。