详解关于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求两个list的差集、交集与并集的方法
Nov 01 Python
python求解水仙花数的方法
May 11 Python
Python中用altzone()方法处理时区的教程
May 22 Python
Anaconda下配置python+opencv+contribx的实例讲解
Aug 06 Python
python tornado微信开发入门代码
Aug 24 Python
Python把对应格式的csv文件转换成字典类型存储脚本的方法
Feb 12 Python
使用Python创建简单的HTTP服务器的方法步骤
Apr 26 Python
Python编写通讯录通过数据库存储实现模糊查询功能
Jul 18 Python
python图的深度优先和广度优先算法实例分析
Oct 26 Python
python中setuptools的作用是什么
Jun 19 Python
使用python-cv2实现Harr+Adaboost人脸识别的示例
Oct 27 Python
Python实现双向链表基本操作
May 25 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的一些小问题
2010/07/03 PHP
PHP入门学习笔记之一
2010/10/12 PHP
PHP跨时区(UTC时间)应用解决方案
2013/01/11 PHP
解析php中用PHPMailer来发送邮件的示例(126.com的例子)
2013/06/24 PHP
一款简单实用的php操作mysql数据库类
2014/12/08 PHP
php使用unset()删除数组中某个单元(键)的方法
2015/02/17 PHP
JQuery对checkbox操作 (循环获取)
2011/05/20 Javascript
jQuery自动完成插件completer附源码下载
2016/01/04 Javascript
BootStrap扔进Django里的方法详解
2016/05/13 Javascript
微信小程序 textarea 详解及简单使用方法
2016/12/05 Javascript
微信小程序图片横向左右滑动案例
2017/05/19 Javascript
jquery动态赋值id与动态取id方法示例
2017/08/21 jQuery
深入浅出es6模板字符串
2017/08/26 Javascript
js 显示日期时间的实例(时间过一秒加1)
2017/10/25 Javascript
jquery获取元素到屏幕四周可视距离的方法
2018/09/05 jQuery
初探Vue3.0 中的一大亮点Proxy的使用
2018/12/06 Javascript
jQuery实现为table表格动态添加或删除tr功能示例
2019/02/19 jQuery
微信小程序页面滚动到指定位置代码实例
2019/09/07 Javascript
JavaScript封装单向链表的示例代码
2020/09/17 Javascript
[04:59]2018DOTA2亚洲邀请赛 4.7 Mineski夺冠时刻
2018/04/09 DOTA
Python多线程编程(一):threading模块综述
2015/04/05 Python
python版本坑:md5例子(python2与python3中md5区别)
2017/06/20 Python
Django后端接收嵌套Json数据及解析详解
2019/07/17 Python
Python Django基础二之URL路由系统
2019/07/18 Python
django框架使用方法详解
2019/07/18 Python
Python lxml库的简单介绍及基本使用讲解
2020/12/22 Python
html5的input的required使用中遇到的问题及解决方法
2018/04/24 HTML / CSS
Probikekit日本:自行车套件,跑步和铁人三项装备
2017/04/03 全球购物
计算机系毕业生推荐信
2013/11/06 职场文书
班级文化建设标语
2014/06/23 职场文书
公司周年庆活动方案
2014/08/25 职场文书
爱护公物演讲稿
2014/09/09 职场文书
医德医魂心得体会
2014/09/11 职场文书
超搞笑婚前保证书
2015/05/08 职场文书
环保建议书作文400字
2015/09/14 职场文书
vue-cil之axios的二次封装与proxy反向代理使用说明
2022/04/07 Vue.js