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

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

主要有User月幌,Tag橙凳,Category,ArticleManager普办,Article,Comment徘钥,Links衔蹲,Ad這幾張表。

Paste_Image.png

Navicat Data Modeler這個(gè)軟件給我的最大感覺(jué)是小巧呈础,使用方便舆驶,但是功能缺失有局限,只適合用于小的項(xiàng)目(個(gè)人感覺(jué)^ ^而钞,不喜勿噴)沙廉。

根據(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號(hào)碼')
    mobile = models.CharField(max_length=11, blank=True, null=True, unique=True, verbose_name='手機(jī)號(hào)碼')
    url = models.URLField(max_length=100, blank=True, null=True, verbose_name='個(gè)人網(wǎng)頁(yè)地址')

    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

# 自定義一個(gè)文章Model的管理器
# 1、新加一個(gè)數(shù)據(jù)處理的方法
# 2臼节、改變?cè)械膓ueryset
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ā)布時(shí)間')
    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

# 評(píng)論模型
class Comment(models.Model):
    content = models.TextField(verbose_name='評(píng)論內(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='個(gè)人網(wǎng)頁(yè)地址')
    date_publish = models.DateTimeField(auto_now_add=True, verbose_name='發(fā)布時(shí)間')
    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='父級(jí)評(píng)論')

    class Meta:
        verbose_name = '評(píng)論'
        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ā)布時(shí)間')
    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ā)布時(shí)間')
    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)驗(yàn)……
root用戶的默認(rèn)密碼為空袱结,不需要輸入,更改密碼是用

>>>mysqladmin -u root password "root"

修改默認(rèn)的sqlite3數(shù)據(jù)庫(kù)為mysql數(shù)據(jù)庫(kù),修改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,生成對(duì)應(yīng)的表

生成如下列表:

Paste_Image.png

createsuperuser添加超級(jí)賬戶

如遇數(shù)據(jù)庫(kù)模型變更途凫,則更新數(shù)據(jù)庫(kù)垢夹,使用以下語(yǔ)句:

makemigrations
syncdb
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市维费,隨后出現(xiàn)的幾起案子果元,更是在濱河造成了極大的恐慌,老刑警劉巖犀盟,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件而晒,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡阅畴,警方通過(guò)查閱死者的電腦和手機(jī)倡怎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)贱枣,“玉大人监署,你說(shuō)我怎么就攤上這事∨Ω纾” “怎么了钠乏?”我有些...
    開封第一講書人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)春塌。 經(jīng)常有香客問(wèn)我晓避,道長(zhǎng),這世上最難降的妖魔是什么只壳? 我笑而不...
    開封第一講書人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任俏拱,我火速辦了婚禮,結(jié)果婚禮上吕世,老公的妹妹穿的比我還像新娘彰触。我一直安慰自己,他們只是感情好命辖,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開白布况毅。 她就那樣靜靜地躺著,像睡著了一般尔艇。 火紅的嫁衣襯著肌膚如雪尔许。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,692評(píng)論 1 305
  • 那天终娃,我揣著相機(jī)與錄音味廊,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛余佛,可吹牛的內(nèi)容都是我干的柠新。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼辉巡,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼恨憎!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起郊楣,我...
    開封第一講書人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤憔恳,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后净蚤,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體钥组,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年今瀑,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了程梦。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡放椰,死狀恐怖作烟,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情砾医,我是刑警寧澤拿撩,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站如蚜,受9級(jí)特大地震影響压恒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜错邦,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一探赫、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧撬呢,春花似錦伦吠、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至芯勘,卻和暖如春箱靴,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背荷愕。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工衡怀, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留棍矛,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓抛杨,卻偏偏與公主長(zhǎng)得像够委,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子怖现,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355

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