Django 學(xué)習(xí)二:設(shè)計(jì)數(shù)據(jù)模型

使用Django開(kāi)發(fā)Web應(yīng)用的過(guò)程中,很多人都是急急忙忙地寫(xiě)視圖,寫(xiě)前端頁(yè)面,把最根本的模型設(shè)計(jì)給忽略了。模型中定義了數(shù)據(jù)如何在數(shù)據(jù)庫(kù)內(nèi)保存,再直白點(diǎn)說(shuō)就是數(shù)據(jù)表的定義。這部分工作體現(xiàn)在Django的代碼中,其實(shí)就是model類(lèi)的設(shè)計(jì)。

一、 數(shù)據(jù)庫(kù)模型設(shè)計(jì)

作為一個(gè)用戶登錄和注冊(cè)項(xiàng)目,需要保存的都是各種用戶的相關(guān)信息。很顯然,我們至少需要一張用戶表User,在用戶表里需要保存下面的信息:

用戶名
密碼
郵箱地址
性別
創(chuàng)建時(shí)間

我們現(xiàn)在就暫定保存這些信息吧,更多的內(nèi)容,請(qǐng)大家在實(shí)際項(xiàng)目中自行添加。

進(jìn)入login/models.py文件,這里將是我們整個(gè)login應(yīng)用中所有模型的存放地點(diǎn),代碼如下:

from django.db import models

# Create your models here.


class User(models.Model):

    gender = (
        ('male', "男"),
        ('female', "女"),
    )

    name = models.CharField(max_length=128, unique=True)
    password = models.CharField(max_length=256)
    email = models.EmailField(unique=True)
    sex = models.CharField(max_length=32, choices=gender, default="男")
    c_time = models.DateTimeField(auto_now_add=True)

    def __str__(self):
        return self.name

    class Meta:
        ordering = ["-c_time"]
        verbose_name = "用戶"
        verbose_name_plural = "用戶"

各字段含義:
name必填,最長(zhǎng)不超過(guò)128個(gè)字符,并且唯一,也就是不能有相同姓名;
password必填,最長(zhǎng)不超過(guò)256個(gè)字符(實(shí)際可能不需要這么長(zhǎng));
email使用Django內(nèi)置的郵箱類(lèi)型,并且唯一;
性別使用了一個(gè)choice,只能選擇男或者女,默認(rèn)為男;
使用str幫助人性化顯示對(duì)象信息;
元數(shù)據(jù)里定義用戶按創(chuàng)建時(shí)間的反序排列,也就是最近的最先顯示;
注意:這里的用戶名指的是網(wǎng)絡(luò)上注冊(cè)的用戶名,不要等同于現(xiàn)實(shí)中的真實(shí)姓名,所以采用了唯一機(jī)制。如果是現(xiàn)實(shí)中可以重復(fù)的人名,那肯定是不能設(shè)置unique的。另外關(guān)于密碼,建議至少128位長(zhǎng)度,原因后面解釋。

二、 設(shè)置數(shù)據(jù)庫(kù)后端

定義好了模型后,就必須選擇我們用來(lái)保存數(shù)據(jù)的數(shù)據(jù)庫(kù)系統(tǒng)。Django支持Mysql,SQLite,Oracle等等。
我已經(jīng)安裝好Mysql,在安裝連接python
由于python3.x里面沒(méi)有了MysqlDB,所以使用python3.6+django連接不上mysql,會(huì)報(bào)錯(cuò) no modul "MysqlDB"。于是就有了一個(gè)替代品,叫pymysql。

  1. 安裝pymysql:

pip3 install pymysql

  1. 把pymysql模塊載入到項(xiàng)目之中(init文件里加入):
import pymysql
pymysql.install_as_MySQLdb()

Django中對(duì)數(shù)據(jù)庫(kù)的設(shè)置在settings文件中,如下部分:

#Database
#https://docs.djangoproject.com/en/1.11/ref/settings/#databases

DATABASES = {
    'default': {
       'ENGINE': 'django.db.backends.mysql',  
        'NAME': 'mysite',  
        'USER':'root',  
        'PASSWORD':'root',  
        'HOST':'127.0.0.1',  
        'PORT':'3306',  
  
    }
}

Django默認(rèn)使用SQLite數(shù)據(jù)庫(kù),并內(nèi)置數(shù)據(jù)庫(kù)訪問(wèn)API,也就是說(shuō)和Python一樣原生支持SQLite。本項(xiàng)目使用SQLite作為后端數(shù)據(jù)庫(kù),因此不需要修改settings中這部分內(nèi)容。如果你想要使用別的數(shù)據(jù)庫(kù),請(qǐng)自行修改該部分設(shè)置。

三、注冊(cè)app

每次創(chuàng)建了新的app后,都需要在全局settings中注冊(cè),這樣Django才知道你有新的應(yīng)用上線了。在settings的下面部分添加‘login’,建議在最后添加個(gè)逗號(hào)。

# Application definition

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

四、創(chuàng)建記錄和數(shù)據(jù)表
app中的models建立好了后,并不會(huì)自動(dòng)地在數(shù)據(jù)庫(kù)中生成相應(yīng)的數(shù)據(jù)表,需要你手動(dòng)創(chuàng)建。

進(jìn)入Pycharm的terminal終端,激活虛擬環(huán)境,執(zhí)行下面的命令:

python manage.py makemigrations
返回結(jié)果:

(mysite_env) F:\Django_course\mysite>python manage.py makemigrations
Migrations for 'login':
  login\migrations\0001_initial.py
    - Create model User

Django自動(dòng)為我們創(chuàng)建了login\migrations\0001_initial.py文件,保存了我們的第一次數(shù)據(jù)遷移工作,也就是創(chuàng)建了User模型。

接著執(zhí)行下面的命令:

python manage.py migrate
Django將在數(shù)據(jù)庫(kù)內(nèi)創(chuàng)建真實(shí)的數(shù)據(jù)表。如果是第一次執(zhí)行該命令,那么一些內(nèi)置的框架,比如auth、session等的數(shù)據(jù)表也將被一同創(chuàng)建,如下所示:

(mysite_env) F:\Django_course\mysite>python manage.py migrate
Operations to perform:
  Apply all migrations: admin, auth, contenttypes, login, sessions
Running migrations:
  Applying contenttypes.0001_initial... OK
  Applying auth.0001_initial... OK
  Applying admin.0001_initial... OK
  Applying admin.0002_logentry_remove_auto_add... OK
  Applying contenttypes.0002_remove_content_type_name... OK
  Applying auth.0002_alter_permission_name_max_length... OK
  Applying auth.0003_alter_user_email_max_length... OK
  Applying auth.0004_alter_user_username_opts... OK
  Applying auth.0005_alter_user_last_login_null... OK
  Applying auth.0006_require_contenttypes_0002... OK
  Applying auth.0007_alter_validators_add_error_messages... OK
  Applying auth.0008_alter_user_username_max_length... OK
  Applying login.0001_initial... OK
  Applying sessions.0001_initial... OK

原文:http://www.liujiangblog.com/course/django/104

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容