Django如何连接MySQL[Django框架]

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.jpg

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

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

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.jpg

eee.jpg

rrr.jpg

以上是 Django如何连接MySQL[Django框架] 的全部内容, 来源链接: utcz.com/z/539710.html

回到顶部