我的环境:
python3.6,
Django2.1.5,
MySQL8.0.15,
win10,
PyCharm,
要求:已经安装了MySQL数据库
1,安装pymysql
Django是使用MySQLdb库来连接MySQL数据库的,。但是MySQLdb不支持Python3,所以使用pymysql代替MySQLdb。
使用pip安装,然后在项目根目录的_init_.py文件中输入:import pymysql pymysql.install_as_MySQLdb()
2,新建数据库
在命令行中用root登录MySQL,并输入:create database db_name default charset = utf8;
3,配置连接参数
在项目根目录的settings.py文件中的DATABASES参数中设置{NAME(库名), USER(登录用户), PASSWORD(用户密码), HOST(主机), PORT(端口号)},并把ENGINE改为MySQL。
如图:
4,设置模型(表)
Django自带了ORM,只需要在app目录的models.py文件中定义表的字段即可(例如:name = models.CharField(max_lenght=30) ),字段定义在继承了models.Model的类中。
设置表名:在该类中添加特殊类:class Meta: db_table = 'User'。注意是在类中。
如图:注意一定要加第二行,其中ShenDeng为你的项目名。
5,同步到数据库(生成表)
1,在命令行中:python manage.py makemigrations # 生成数据库同步脚本。 # 在这一步可能会报错,解决方法在下面第6步。
2,在命令行中:python manage.py migrate # 同步数据库。
6,错误(拒绝访问):pymysql.err.OperationalError: (1045, "Access denied for user 'root'@'localhost')
错误原因:由于MySQL的root用户默认只能由本地主机(即: localhost)访问,所以通过pymysql远程访问时会拒绝访问。
解决方法1:更改root用户的密码认证方式。在cmd中登录MySQL,并输入:alter user 'root'@'localhost' identified with mysql_native_password by 123456;
解决方法2:授权root用户远程登录。grant all on *.* to 'root'@'%' identified by 123456;
上面两种方法都可以,完成后重复步骤5即可。
7,验证是否成功( 在cmd中):
1,用root登录:mysql> mysql -u root -p; 输入密码。
2,查看表是否存在:mysql> use <数据库名>;
mysql> show tables;
ps: 一般会有很多表,其他的暂时不用管,找到我们要建的表就行了!
8,往表中添加数据:
新建一个.py文件输入以下内容然后单独运行就可以了。(User为继承了models.Model的类)