Django如何连接MySQL
Django连接MySQL
1、创建数据库 (注意设置 数据的字符编码)
由于Django自带的orm是data_first类型的ORM,使用前必须先创建数据库。
create database day70 default character set utf8 collate utf8_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的方式
import pymysql pymysql.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', ]
相关推荐:《Python视频教程》
5、models.py创建表
6、进行数据迁移
在winds cmd或者Linux shell的项目的manage.py目录下执行
python manage.py makemigrations #根据app下的migrations目录中的记录,检测当前model层代码是否发生变化? python manage.py migrate #把orm代码转换成sql语句去数据库执行 python manage.py migrate --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.设置新增字段默认值为当前时间
Please enter the default value now, as valid Python The datetime and django.utils.timezone modules are available, so you can do e.g. timezone.now Type 'exit' to exit this prompt >>> 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之modles.py创建表
modles.py创建表ORM字段介绍Djano提供了很多字段类型,比如URL/Email/IP/ 但是mysql数据没有这些类型,这类型存储到数据库上本质是字符串数据类型,其主要目的是为了封装底层S ...