欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解關(guān)于Django中ORM數(shù)據(jù)庫(kù)遷移的配置

 更新時(shí)間:2018年10月08日 09:59:20   作者:蟹小老板  
這篇文章主要介紹了詳解關(guān)于Django中ORM數(shù)據(jù)庫(kù)遷移的配置,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

簡(jiǎn)介

ORM:

關(guān)系對(duì)象映射。定義一個(gè)類(lèi)自動(dòng)生成數(shù)據(jù)庫(kù)的表結(jié)構(gòu)。

創(chuàng)建數(shù)據(jù)庫(kù)的時(shí)候,一般有以下幾種常用數(shù)據(jù)類(lèi)型:數(shù)字、字符串以及時(shí)間。

ORM分為兩種:

  • DB First 數(shù)據(jù)庫(kù)里先創(chuàng)建數(shù)據(jù)庫(kù)表結(jié)構(gòu),根據(jù)表結(jié)構(gòu)生成類(lèi),根據(jù)類(lèi)操作數(shù)據(jù)庫(kù)
  • Code First 先寫(xiě)代碼,執(zhí)行代碼創(chuàng)建數(shù)據(jù)庫(kù)表結(jié)構(gòu)

主流的orm都是code first。django 的orm也是code first,所以學(xué)的時(shí)候,本質(zhì)就分為兩塊:

  • 根據(jù)類(lèi)自動(dòng)創(chuàng)建數(shù)據(jù)庫(kù)表
  • 根據(jù)類(lèi)對(duì)數(shù)據(jù)庫(kù)表中的數(shù)據(jù)進(jìn)行各種操作

手動(dòng)創(chuàng)建mysql數(shù)據(jù)庫(kù),例如db_Django03

create database root charset=utf8;

1,若想將模型轉(zhuǎn)為mysql數(shù)據(jù)庫(kù)中的表,需要在settings中配置:

DATABASES = {
  'default': {
    'ENGINE': 'django.db.backends.mysql',
    'NAME':'bms',        # 要連接的數(shù)據(jù)庫(kù),連接前需要?jiǎng)?chuàng)建好
    'USER':'root',       # 連接數(shù)據(jù)庫(kù)的用戶名
    'PASSWORD':'',       # 連接數(shù)據(jù)庫(kù)的密碼
    'HOST':'127.0.0.1',    # 連接主機(jī),默認(rèn)本級(jí)
    'PORT':3306        # 端口 默認(rèn)3306
  }
}

2,需要激活我們的mysql。然后,啟動(dòng)項(xiàng)目,會(huì)報(bào)錯(cuò):no module named MySQLdb 。這是因?yàn)閐jango默認(rèn)你導(dǎo)入的驅(qū)動(dòng)是MySQLdb,可是MySQLdb 對(duì)于py3有很大問(wèn)題,所以我們需要的驅(qū)動(dòng)是PyMySQL 所以,我們只需要找到項(xiàng)目名文件下的init,在里面寫(xiě)入:

import pymysql
pymysql.install_as_MySQLdb()

*注意1,需確保配置文件中的INSTALLED_APPS中寫(xiě)入我們創(chuàng)建的app名稱

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

*注意2,如果報(bào)錯(cuò)如下:

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

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

通過(guò)查找路徑C:\Programs\Python\Python36-32\Lib\site-packages\Django-2.0-py3.6.egg\django\db\backends\mysql 這個(gè)路徑里的文件把

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

注釋掉 就OK了。

*注意3,如果想打印orm轉(zhuǎn)換過(guò)程中的sql,需要在settings中進(jìn)行如下配置:

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論