django模型設(shè)計及blog/models.py設(shè)計及使用

跟著老師用Navicat Data Modeler畫了一下大概的數(shù)據(jù)模型

主要有User,Tag,Category,ArticleManager,Article,Comment,Links,Ad這幾張表。

Paste_Image.png

Navicat Data Modeler這個軟件給我的最大感覺是小巧,使用方便,但是功能缺失有局限,只適合用于小的項目(個人感覺^ ^,不喜勿噴)。

根據(jù)pdm在blog/models.py中定義模型

#-*- coding: utf-8 -*-
from __future__ import unicode_literals
from django.contrib.auth.models import AbstractUser

from django.db import models

# Create your models here.
# 用戶模型.
# 第一種:采用的繼承方式擴(kuò)展用戶信息(本系統(tǒng)采用)
# 擴(kuò)展:關(guān)聯(lián)的方式去擴(kuò)展用戶信息
class User(AbstractUser):
    avatar = models.ImageField(upload_to='avatar/%Y/%m', default='avatar/default.png', max_length=200, blank=True, null=True, verbose_name='用戶頭像')
    qq = models.CharField(max_length=20, blank=True, null=True, verbose_name='QQ號碼')
    mobile = models.CharField(max_length=11, blank=True, null=True, unique=True, verbose_name='手機(jī)號碼')
    url = models.URLField(max_length=100, blank=True, null=True, verbose_name='個人網(wǎng)頁地址')

    class Meta:
        verbose_name = '用戶'
        verbose_name_plural = verbose_name
        ordering = ['-id']

    def __unicode__(self):
        return self.username

# tag(標(biāo)簽)
class Tag(models.Model):
    name = models.CharField(max_length=30, verbose_name='標(biāo)簽名稱')

    class Meta:
        verbose_name = '標(biāo)簽'
        verbose_name_plural = verbose_name

    def __unicode__(self):
        return self.name

# 分類
class Category(models.Model):
    name = models.CharField(max_length=30, verbose_name='分類名稱')
    index = models.IntegerField(default=999,verbose_name='分類的排序')

    class Meta:
        verbose_name = '分類'
        verbose_name_plural = verbose_name
        ordering = ['index', 'id']

    def __unicode__(self):
        return self.name

# 自定義一個文章Model的管理器
# 1、新加一個數(shù)據(jù)處理的方法
# 2、改變原有的queryset
class ArticleManager(models.Manager):
    def distinct_date(self):
        distinct_date_list = []
        date_list = self.values('date_publish')
        for date in date_list:
            date = date['date_publish'].strftime('%Y/%m文章存檔')
            if date not in distinct_date_list:
                distinct_date_list.append(date)
        return distinct_date_list

# 文章模型
class Article(models.Model):
    title = models.CharField(max_length=50, verbose_name='文章標(biāo)題')
    desc = models.CharField(max_length=50, verbose_name='文章描述')
    content = models.TextField(verbose_name='文章內(nèi)容')
    click_count = models.IntegerField(default=0, verbose_name='點(diǎn)擊次數(shù)')
    is_recommend = models.BooleanField(default=False, verbose_name='是否推薦')
    date_publish = models.DateTimeField(auto_now_add=True, verbose_name='發(fā)布時間')
    user = models.ForeignKey(User, verbose_name='用戶')
    category = models.ForeignKey(Category, blank=True, null=True, verbose_name='分類')
    tag = models.ManyToManyField(Tag, verbose_name='標(biāo)簽')

    objects = ArticleManager()

    class Meta:
        verbose_name = '文章'
        verbose_name_plural = verbose_name
        ordering = ['-date_publish']

    def __unicode__(self):
        return self.title

# 評論模型
class Comment(models.Model):
    content = models.TextField(verbose_name='評論內(nèi)容')
    username = models.CharField(max_length=30, blank=True, null=True, verbose_name='用戶名')
    email = models.EmailField(max_length=50, blank=True, null=True, verbose_name='郵箱地址')
    url = models.URLField(max_length=100, blank=True, null=True, verbose_name='個人網(wǎng)頁地址')
    date_publish = models.DateTimeField(auto_now_add=True, verbose_name='發(fā)布時間')
    user = models.ForeignKey(User, blank=True, null=True, verbose_name='用戶')
    article = models.ForeignKey(Article, blank=True, null=True, verbose_name='文章')
    pid = models.ForeignKey('self', blank=True, null=True, verbose_name='父級評論')

    class Meta:
        verbose_name = '評論'
        verbose_name_plural = verbose_name

    def __unicode__(self):
        return str(self.id)

# 友情鏈接
class Links(models.Model):
    title = models.CharField(max_length=50, verbose_name='標(biāo)題')
    description = models.CharField(max_length=200, verbose_name='友情鏈接描述')
    callback_url = models.URLField(verbose_name='url地址')
    date_publish = models.DateTimeField(auto_now_add=True, verbose_name='發(fā)布時間')
    index = models.IntegerField(default=999, verbose_name='排列順序(從小到大)')

    class Meta:
        verbose_name = '友情鏈接'
        verbose_name_plural = verbose_name
        ordering = ['index', 'id']

    def __unicode__(self):
        return self.title

# 廣告
class Ad(models.Model):
    title = models.CharField(max_length=50, verbose_name='廣告標(biāo)題')
    description = models.CharField(max_length=200,  verbose_name='廣告描述')
    image_url = models.ImageField(upload_to='ad/%Y/%m', verbose_name='圖片路徑')
    callback_url = models.URLField(null=True, blank=True, verbose_name='回調(diào)url')
    date_publish = models.DateTimeField(auto_now_add=True, verbose_name='發(fā)布時間')
    index = models.IntegerField(default=999, verbose_name='排列順序(從小到大)')

    class Meta:
        verbose_name = u'廣告'
        verbose_name_plural = verbose_name
        ordering = ['index', 'id']

    def __unicode__(self):
        return self.title

下載安裝mysql,下載的mysql-community-server版,為免安裝版。

設(shè)置參考百度經(jīng)驗……
root用戶的默認(rèn)密碼為空,不需要輸入,更改密碼是用

>>>mysqladmin -u root password "root"

修改默認(rèn)的sqlite3數(shù)據(jù)庫為mysql數(shù)據(jù)庫,修改settings.py

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

由于引用django.contrib.auth.models.AbstractUser

AUTH_USER_MODEL = 'blog.User'

pycharm中Tools>run manage.py Task 中運(yùn)行

makemigrations#生產(chǎn)sql
migrate             #執(zhí)行sql,生成對應(yīng)的表

生成如下列表:

Paste_Image.png

createsuperuser添加超級賬戶

如遇數(shù)據(jù)庫模型變更,則更新數(shù)據(jù)庫,使用以下語句:

makemigrations
syncdb
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,885評論 6 541
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,312評論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,993評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,667評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,410評論 6 411
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,778評論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,775評論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,955評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,521評論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,266評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,468評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,998評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,696評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,095評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,385評論 1 294
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,193評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,431評論 2 378

推薦閱讀更多精彩內(nèi)容