溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Django中如何配置ORM數據庫遷移

發布時間:2021-07-24 14:20:28 來源:億速云 閱讀:110 作者:小新 欄目:開發技術

這篇文章主要介紹了Django中如何配置ORM數據庫遷移,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

簡介

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',
    },
  }
}

感謝你能夠認真閱讀完這篇文章,希望小編分享的“Django中如何配置ORM數據庫遷移”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女