天天看點

python設計模型_設計資料模型

使用Django開發Web應用的過程中,很多人都是急急忙忙地寫視圖,寫前端頁面,把最根本的模型設計給忽略了。模型中定義了資料如何在資料庫内儲存,也就是資料表的定義方式。這部分工作展現在Django的代碼中,其實就是model類的設計。

一、 資料庫模型設計

作為一個使用者登入和注冊項目,需要儲存的都是各種使用者的相關資訊。很顯然,我們至少需要一張使用者表User,在使用者表裡需要儲存下面的資訊:

使用者名

密碼

郵箱位址

性别

建立時間

我們現在就暫定儲存這些資訊吧,更多的内容,請大家在實際項目中自行添加。

進入login/models.py檔案,這裡将是我們整個login應用中所有模型的存放地點,代碼如下:

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: 必填,最長不超過128個字元,并且唯一,也就是不能有相同姓名;

password: 必填,最長不超過256個字元(實際可能不需要這麼長);

email: 使用Django内置的郵箱類型,并且唯一;

sex: 性别,使用了一個choice,隻能選擇男或者女,預設為男;

使用__str__方法幫助人性化顯示對象資訊;

中繼資料裡定義使用者按建立時間的反序排列,也就是最近的最先顯示;

注意:這裡的使用者名指的是網絡上注冊的使用者名,不要等同于現實中的真實姓名,是以采用了唯一機制。如果是現實中的人名,那是可以重複的,肯定是不能設定unique的。另外關于密碼,建議至少128位長度,原因後面解釋。

二、 設定資料庫後端

定義好了模型後,就必須選擇我們用來儲存資料的資料庫系統。Django支援Mysql,SQLite,Oracle等等。

Django中對資料庫的設定在settings檔案中,如下部分:

# Database

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

DATABASES = {

'default': {

'ENGINE': 'django.db.backends.sqlite3',

'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),

}

}

Django預設使用SQLite資料庫,并内置SQLite資料庫的通路API,也就是說和Python一樣原生支援SQLite。本項目使用SQLite作為後端資料庫,是以不需要修改settings中這部分内容。如果你想要使用别的資料庫,請自行修改該部分設定。

三、注冊app

每次建立了新的app後,都需要在全局settings中注冊,這樣Django才知道你有新的應用上線了。在settings的下面部分添加‘login’,建議在最後添加個逗号。

# Application definition

INSTALLED_APPS = [

'django.contrib.admin',

'django.contrib.auth',

'django.contrib.contenttypes',

'django.contrib.sessions',

'django.contrib.messages',

'django.contrib.staticfiles',

'login',

]

四、建立記錄和資料表

app中的models建立好了後,并不會自動地在資料庫中生成相應的資料表,需要你手動建立。

進入Pycharm的terminal終端,執行下面的指令:

python manage.py makemigrations

傳回結果:

(venv) D:\work\2019\for_test\mysite>python manage.py makemigrations

Migrations for 'login':

login\migrations\0001_initial.py

- Create model User

Django自動為我們建立了login\migrations\0001_initial.py檔案,儲存了我們的第一次資料遷移工作,也就是建立了User模型。

接着執行下面的指令:

python manage.py migrate

Django将在資料庫内建立真實的資料表。如果是第一次執行該指令,那麼一些内置的架構,比如auth、session等的資料表也将被一同建立,如下所示:

(venv) D:\work\2019\for_test\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 admin.0003_logentry_add_action_flag_choices... 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 auth.0009_alter_user_last_name_max_length... OK

Applying auth.0010_alter_group_name_max_length... OK

Applying auth.0011_update_proxy_permissions... OK

Applying login.0001_initial... OK

Applying sessions.0001_initial... OK