详解关于Django中ORM数据库迁移的配置


Posted in Python onOctober 08, 2018

简介

ORM:

关系对象映射。定义一个类自动生成数据库的表结构。

创建数据库的时候,一般有以下几种常用数据类型:数字、字符串以及时间。

ORM分为两种:

  • DB First 数据库里先创建数据库表结构,根据表结构生成类,根据类操作数据库
  • Code First 先写代码,执行代码创建数据库表结构

主流的orm都是code first。django 的orm也是code first,所以学的时候,本质就分为两块:

  • 根据类自动创建数据库表
  • 根据类对数据库表中的数据进行各种操作

手动创建mysql数据库,例如db_Django03

create database root charset=utf8;

1,若想将模型转为mysql数据库中的表,需要在settings中配置:

DATABASES = {
  'default': {
    'ENGINE': 'django.db.backends.mysql',
    'NAME':'bms',      # 要连接的数据库,连接前需要创建好
    'USER':'root',


 # 连接数据库的用户名
    'PASSWORD':'',


 # 连接数据库的密码
    'HOST':'127.0.0.1',    # 连接主机,默认本级
    'PORT':3306  
    # 端口 默认3306
  }
}

2,需要激活我们的mysql。然后,启动项目,会报错:no module named MySQLdb 。这是因为django默认你导入的驱动是MySQLdb,可是MySQLdb 对于py3有很大问题,所以我们需要的驱动是PyMySQL 所以,我们只需要找到项目名文件下的init,在里面写入:

import pymysql
pymysql.install_as_MySQLdb()

*注意1,需确保配置文件中的INSTALLED_APPS中写入我们创建的app名称

INSTALLED_APPS = [
  'django.contrib.admin',
  'django.contrib.auth',
  'django.contrib.contenttypes',
  'django.contrib.sessions',
  'django.contrib.messages',
  'django.contrib.staticfiles',
  "book"
]

*注意2,如果报错如下:

django.core.exceptions.ImproperlyConfigured: mysqlclient 1.3.3 or newer is required; you have 0.7.11.None

MySQLclient目前只支持到python3.4,因此如果使用的更高版本的python,需要修改如下:

通过查找路径C:\Programs\Python\Python36-32\Lib\site-packages\Django-2.0-py3.6.egg\django\db\backends\mysql 这个路径里的文件把

if version < (1, 3, 3):
   raise ImproperlyConfigured("mysqlclient 1.3.3 or newer is required; you have %s" % Database.__version__)

注释掉 就OK了。

*注意3,如果想打印orm转换过程中的sql,需要在settings中进行如下配置:

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
用Python分析3天破10亿的《我不是药神》到底神在哪?
Jul 12 Python
python实现括号匹配的思路详解
Aug 23 Python
详解python中Numpy的属性与创建矩阵
Sep 10 Python
Python玩转加密的技巧【推荐】
May 13 Python
Python 实现还原已撤回的微信消息
Jun 18 Python
Python格式化字符串f-string概览(小结)
Jun 18 Python
python cv2在验证码识别中应用实例解析
Dec 25 Python
浅析Python3 pip换源问题
Jan 06 Python
python实现ftp文件传输系统(案例分析)
Mar 20 Python
python实现画图工具
Aug 27 Python
Python+OpenCV图像处理——实现直线检测
Oct 23 Python
python 实现mysql自动增删分区的方法
Apr 01 Python
面向初学者的Python编辑器Mu
Oct 08 #Python
Django 实现购物车功能的示例代码
Oct 08 #Python
一行代码让 Python 的运行速度提高100倍
Oct 08 #Python
Python django使用多进程连接mysql错误的解决方法
Oct 08 #Python
Python Pandas批量读取csv文件到dataframe的方法
Oct 08 #Python
Python中的函数式编程:不可变的数据结构
Oct 08 #Python
详解多线程Django程序耗尽数据库连接的问题
Oct 08 #Python
You might like
实现PHP多线程异步请求的3种方法
2014/01/17 PHP
PHP引用(&amp;)各种使用方法实例详解
2014/03/20 PHP
PHP获取当前文件的父目录方法汇总
2016/07/21 PHP
php 解决扫描二维码下载跳转问题
2017/01/13 PHP
JS 强制设为首页的代码
2009/01/31 Javascript
jQuery Ajax文件上传(php)
2009/06/16 Javascript
前淘宝前端开发工程师阿当的PPT中有JS技术理念问题
2010/01/15 Javascript
jQuery EasyUI API 中文文档 DateTimeBox日期时间框
2011/10/16 Javascript
jqGrid增加时--判断开始日期与结束日期(实例解析)
2013/11/08 Javascript
HTML,CSS,JavaScript速查表推荐
2014/12/02 Javascript
Angular2 多级注入器详解及实例
2016/10/30 Javascript
详解Angular的双向数据绑定(MV-VM)
2016/12/26 Javascript
原生nodejs使用websocket代码分享
2018/04/07 NodeJs
新手简单了解vue
2019/05/29 Javascript
基于vue-draggable 实现三级拖动排序效果
2020/01/10 Javascript
Python多进程机制实例详解
2015/07/02 Python
Python每天必学之bytes字节
2016/01/28 Python
Python使用plotly绘制数据图表的方法
2017/07/18 Python
Python使用回溯法子集树模板获取最长公共子序列(LCS)的方法
2017/09/08 Python
python实现微信自动回复功能
2018/04/11 Python
Python如何优雅获取本机IP方法
2019/11/10 Python
python_array[0][0]与array[0,0]的区别详解
2020/02/18 Python
如何基于matlab相机标定导出xml文件
2020/11/02 Python
python Autopep8实现按PEP8风格自动排版Python代码
2021/03/02 Python
Topshop法国官网:英国快速时尚品牌
2018/04/08 全球购物
Delphi软件工程师试题
2013/01/29 面试题
测绘工程专业个人自我评价
2013/12/01 职场文书
大学生旷课检讨书
2014/01/22 职场文书
小学生开学感言
2014/02/28 职场文书
党员教师个人对照检查材料范文
2014/09/25 职场文书
2015年度党员个人总结
2015/02/14 职场文书
2015年法制宣传月活动总结
2015/03/26 职场文书
安全承诺书格式范本
2015/04/28 职场文书
人口与计划生育责任书
2015/05/09 职场文书
初婚初育证明范本
2015/06/18 职场文书
Python词云的正确实现方法实例
2021/05/08 Python