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

django連接Mysql中已有數(shù)據(jù)庫的方法詳解

 更新時(shí)間:2022年05月30日 11:54:21   作者:ChangYan.  
眾所周知Django較為適合原生開發(fā),即通過該框架搭建一個(gè)全新的項(xiàng)目,通過在修改models.py來創(chuàng)建新的數(shù)據(jù)庫表,下面這篇文章主要給大家介紹了關(guān)于django連接Mysql中已有數(shù)據(jù)庫的相關(guān)資料,需要的朋友可以參考下

我的Mysql中已經(jīng)有了項(xiàng)目需要使用的相關(guān)數(shù)據(jù)庫,現(xiàn)在需要通過django來獲取Mysql里的數(shù)據(jù)并使用,下面記錄配置django與mysql的連接過程。

(此處默認(rèn)您已經(jīng)建好了django框架,如果沒有準(zhǔn)備好django,請(qǐng)參照我本篇文章

http://www.dbjr.com.cn/article/249861.htm

首先需要在項(xiàng)目的settings.py文件中配置mysql的連接信息:把之前配置的sqlite配置信息替換。
之前默認(rèn)的數(shù)據(jù)庫配置信息如圖,是與sqlite連接的

現(xiàn)在我們需要替換為自己本地的Mysql信息,并連接我的ry-vue數(shù)據(jù)庫,代碼如下,相應(yīng)的屬性需要對(duì)應(yīng)自己的Mysql進(jìn)行配置,如果不清楚請(qǐng)看接下來的圖片:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'HOST': '127.0.0.1',		# 要連接的數(shù)據(jù)庫ip
        'PORT': '3306',				# 數(shù)據(jù)庫連接端口,一般默認(rèn)為3306
        'NAME': 'ry-vue',			# 已經(jīng)存在的數(shù)據(jù)庫名稱
        'USER': 'root',				# 用戶名
        'PASSWORD': '',				# 用戶密碼
        'OPTIONS': {
            'init_command': "SET sql_mode='STRICT_TRANS_TABLES'",
            }
    }
}

Mysql的相關(guān)對(duì)應(yīng)信息查看過程如圖:

就能看到對(duì)應(yīng)的連接信息:

然后在settings.py同級(jí)目錄的__init__.py文件中增加下面代碼,導(dǎo)入mysql的配置

# coding=utf-8

import pymysql
pymysql.install_as_MySQLdb()

如圖:

這時(shí)你會(huì)發(fā)現(xiàn)導(dǎo)入的pymysql有報(bào)錯(cuò),這是因?yàn)槲覀冞€沒有安裝pymysql包,根據(jù)下圖過程來進(jìn)行pymysql的安裝:

等安裝成功后就不會(huì)報(bào)錯(cuò)了。

之后導(dǎo)入數(shù)據(jù)庫中的表到django里,執(zhí)行下邊的命令,該命令的意思是將對(duì)應(yīng)數(shù)據(jù)庫的表自動(dòng)生成到models.py文件中。

python manage.py inspectdb > models.py

等幾秒或者刷新一下文件夾,就能在 manage.py 的下面出現(xiàn)一個(gè) models.py,里面包含了已有數(shù)據(jù)庫的所有表及結(jié)構(gòu)。

可以看到第一個(gè)表是bank,與我的數(shù)據(jù)庫ry-vue里的顯示完全一樣

之后把想要使用的表的 managed 都改成 True。比如我想要在django中操作scratch_choice_answer表里的信息,則需要通過類名找到該表,然后修改如圖:

接著將需要用的表復(fù)制到你的程序需要使用的目錄下。 如果基本上都會(huì)用到,那就復(fù)制整個(gè)文件,比如我的register只里需要用到scratch_choice_answer表里的信息,那么我就操作如下,只復(fù)制 class ScratchChoiceAnswer這部分的內(nèi)容到需要的文件夾下就可以。

因?yàn)樾枰玫絩egister這個(gè)app,再次確認(rèn)一下此文件是否在settings注冊(cè)過

等到把需要的內(nèi)容復(fù)制到要使用的文件夾之后,剛剛自動(dòng)生成的models.py已經(jīng)沒有用了,就可以刪除了,注意該文件位置是在manage.py下邊。
下次如果只單獨(dú)使用一個(gè)表,就可以使用如下的代碼進(jìn)行mysql的生成,而不需要全部進(jìn)行生成,代碼如下,表示只生成scratch_choice_answer表里的信息。

python manage.py inspectdb scratch_choice_answer

然后只需將上圖紅框部分的內(nèi)容復(fù)制到需要的models.py里就可以。注意要將managed 的 False 設(shè)置為 True

然后運(yùn)行如下指令,該指令就是將django與數(shù)據(jù)庫進(jìn)行同步,可以進(jìn)行增刪改查操作。

python manage.py migrate

等顯示OK后就可以通過django對(duì)數(shù)據(jù)庫進(jìn)行操作了。

(這時(shí)候刷新一下Mysql,會(huì)發(fā)現(xiàn)自動(dòng)生成了auth_xxx和django_xxx的表,這個(gè)是django用來記錄對(duì)數(shù)據(jù)庫的一些操作的,就放那兒不用管,對(duì)整個(gè)項(xiàng)目的運(yùn)行沒有影響)

連接成功驗(yàn)證

我需要獲取一下scratch_choice_answer表里的choice_id,如圖

則輸入代碼如下:

from register.models import ScratchChoiceAnswer

answer = ScratchChoiceAnswer.objects.all().values('choice_id')
print(answer)

然后運(yùn)行django,(如果這時(shí)候報(bào)錯(cuò)ValueError: source code string cannot contain null bytes,其實(shí)是models里的編碼問題,解決方法:

運(yùn)行django框架出現(xiàn)如下報(bào)錯(cuò),我出現(xiàn)該問題是由于數(shù)據(jù)庫編碼不正確

解決方法如下:

打開models.py,將編碼改為UTF-8

django運(yùn)行成功后可以看到獲取到Mysql里的值

大功告成!

總結(jié)

到此這篇關(guān)于django連接Mysql中已有數(shù)據(jù)庫的文章就介紹到這了,更多相關(guān)django連接Mysql數(shù)據(jù)庫內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論