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    #只记录变化,不提交数据库操作

1562031918189836.png

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

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

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

www.png

eee.png

rrr.png

modles.py创建表ORM字段介绍Djano提供了很多字段类型,比如URL/Email/IP/ 但是mysql数据没有这些类型,这类型存储到数据库上本质是字符串数据类型,其主要目的是为了封装底层S ...