一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - 詳解關于Django中ORM數據庫遷移的配置

詳解關于Django中ORM數據庫遷移的配置

2021-04-05 00:44蟹小老板 Python

這篇文章主要介紹了詳解關于Django中ORM數據庫遷移的配置,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看

簡介

ORM:

關系對象映射。定義一個類自動生成數據庫的表結構。

創建數據庫的時候,一般有以下幾種常用數據類型:數字、字符串以及時間。

ORM分為兩種:

  • DB First 數據庫里先創建數據庫表結構,根據表結構生成類,根據類操作數據庫
  • Code First 先寫代碼,執行代碼創建數據庫表結構

主流的orm都是code first。django 的orm也是code first,所以學的時候,本質就分為兩塊:

  • 根據類自動創建數據庫表
  • 根據類對數據庫表中的數據進行各種操作

手動創建mysql數據庫,例如db_Django03

?
1
create database root charset=utf8;

1,若想將模型轉為mysql數據庫中的表,需要在settings中配置:

?
1
2
3
4
5
6
7
8
9
10
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,在里面寫入:

?
1
2
import pymysql
pymysql.install_as_MySQLdb()

*注意1,需確保配置文件中的INSTALLED_APPS中寫入我們創建的app名稱

?
1
2
3
4
5
6
7
8
9
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 這個路徑里的文件把

?
1
2
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中進行如下配置:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
LOGGING = {
  'version': 1,
  'disable_existing_loggers': False,
  'handlers': {
    'console':{
      'level':'DEBUG',
      'class':'logging.StreamHandler',
    },
  },
  'loggers': {
    'django.db.backends': {
      'handlers': ['console'],
      'propagate': True,
      'level':'DEBUG',
    },
  }
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:http://www.cnblogs.com/xh-0205/p/9740666.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 91在线精品国产 | 污小说h | 欧产日产国产精品专区 | 国产成人啪精品视频站午夜 | 性印度freehd | 男人天堂亚洲 | 久久精品观看影院2828 | 国产精品嫩草影院在线 | 2012手机在线中文字幕 | 亚洲国产欧美目韩成人综合 | 亚洲2017天堂色无码 | 无人区在线观看免费完整版免费 | 小草高清视频免费直播 | 99久久99久久久精品齐齐鬼色 | 好紧好爽再叫浪一点点潘金莲 | 精品视频手机在线观看免费 | 免费真实播放国产乱子伦 | 五月婷婷在线免费观看 | 女人扒开下面让男人桶爽视频 | 欧美日韩亚洲一区二区三区在线观看 | 扒开大腿狠狠挺进视频 | 女子监狱第二季在线观看免费完整版 | 日韩亚洲欧美综合一区二区三区 | 久久久精品日本一区二区三区 | 糖心vlog视频永久破解版 | 国产裸舞福利资源在线视频 | 大陆国产精品视频 | 青青草国产精品免费 | 成人快手破解版 | 日韩精品特黄毛片免费看 | 操好爽 | 贵妇的私人性俱乐部 | 国产欧美国产综合第一区 | 青青草伊人久久 | 欧美一区二区三区四区视频 | gay中国| 91久久国产综合精品 | 我不卡影院手机在线观看 | 午夜想想爱午夜剧场 | 欧美日韩一区二区三区在线播放 | 男女刺激高清视频在线观看 |