|

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 

 |