这篇文章主要介绍Django中连接MySQL的方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

Django连接MySQL

1、创建数据库 (注意设置 数据的字符编码)

由于Django自带的orm是data_first类型的ORM,使用前必须先创建数据库。

createdatabaseday70defaultcharactersetutf8collateutf8_general_ci;

2、修改project中的settings.py文件中设置 连接 MySQL数据库(Django默认使用的是sqllite数据库)

DATABASES={'default':{'ENGINE':'django.db.backends.mysql','NAME':'day70','USER':'eric','PASSWORD':'123123','HOST':'192.168.182.128','PORT':'3306',}}

扩展:查看orm操作执行的原生SQL语句

在project中的settings.py文件增加。

LOGGING={'version':1,'disable_existing_loggers':False,'handlers':{'console':{'level':'DEBUG','class':'logging.StreamHandler',},},'loggers':{'django.db.backends':{'handlers':['console'],'propagate':True,'level':'DEBUG',},}}

3、修改project 中的__init__py 文件设置 Django默认连接MySQL的方式

importpymysqlpymysql.install_as_MySQLdb()

4、setings文件注册APP

INSTALLED_APPS=['django.contrib.admin','django.contrib.auth','django.contrib.contenttypes','django.contrib.sessions','django.contrib.messages','django.contrib.staticfiles','app01.apps.App01Config',]

5、models.py创建表

6、进行数据迁移

在winds cmd或者Linux shell的项目的manage.py目录下执行

pythonmanage.pymakemigrations#根据app下的migrations目录中的记录,检测当前model层代码是否发生变化?pythonmanage.pymigrate#把orm代码转换成sql语句去数据库执行pythonmanage.pymigrate--fake#只记录变化,不提交数据库操作

扩展:修改表结构之后常见报错

这个报错:因为表创建之时,新增字段既没有设置默认值,也没有设置新增字段可为空,去对应原有数据导致;

2种解决方法:

1.设置新增字段可以为空

startdate=models.CharField(max_length=255,verbose_name="任务开始时间",null=True,blank=True)Handledate=models.CharField(max_length=255,verbose_name="开始处理时间",null=True,blank=True)Handledone=models.CharField(max_length=255,verbose_name="处理完毕时间",null=True,blank=True)enddate=models.CharField(max_length=255,verbose_name="任务结束时间",null=True,blank=True)WorkTime_cost=models.CharField(max_length=255,verbose_name='工作耗时',null=True,blank=True)

2.设置新增字段默认值为当前时间

Pleaseenterthedefaultvaluenow,asvalidPythonThedatetimeanddjango.utils.timezonemodulesareavailable,soyoucandoe.g.timezone.nowType'exit'toexitthisprompt>>>timezone.now()

更多问题

python manage.py makemigrations :把你写在models中的代码翻译成增、删、改的 SQL 语句;

python manage.py migrate;讲python manage.py makemigrations翻译的SQL语句去数据库执行;

python manage.py migrate --fake;假设 migrate 把所有SQL语句执行成功了;

我在使用Django构建表结构的时候很长一段时间都是没有了解以上3条语句的执行意义,所有经常在修改表结构之后出现报错;

出现报错的原因:

无非就是 makemigrations翻译的 SQL,跟数据库里面真实的表结构 相互冲突,增加、删除不了表、外键关系;

所以遇到报错 你应该先把model中的代码注释掉-----》python manage.py migrate --fake------》python manage.py makemigrations

去数据库把已经存在的表、外键删掉(确保数据库目前的状态,可以让makemigrations翻译出来的SQL语句在数据库里执行成功;然后migrate)--------》 python manage.py migrate;

7.设置pycharm可视化MySQL

以上是Django中连接MySQL的方法的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!