使用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。
- 安裝pymysql:
pip3 install pymysql
- 把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