1. 程式人生 > >Django筆記入門小專案

Django筆記入門小專案

設計介紹

  • 本示例完成“圖書-英雄”資訊的維護,需要儲存兩種資料:圖書、英雄
  • 圖書表結構設計:
    • 表名:BookInfo
    • 圖書名稱:btitle
    • 圖書釋出時間:bpub_date
  • 英雄表結構設計:
    • 表名:HeroInfo
    • 英雄姓名:hname
    • 英雄性別:hgender
    • 英雄簡介:hcontent
    • 所屬圖書:hbook
  • 圖書-英雄的關係為一對多

資料庫配置

  • 在settings.py檔案中,通過DATABASES項進行資料庫設定
  • django支援的資料庫包括:sqlite、mysql等主流資料庫
  • Django預設使用SQLite資料庫

建立應用

  • 在一個專案中可以建立一到多個應用,每個應用進行一種業務處理
  • 建立應用的命令:
python manage.py startapp booktest

定義模型類

  • 有一個數據表,就有一個模型類與之對應
  • 開啟models.py檔案,定義模型類
  • 引入包from django.db import models
  • 模型類繼承自models.Model類
  • 說明:不需要定義主鍵列,在生成時會自動新增,並且值為自動增長
  • 當輸出物件時,會呼叫物件的str方法
from django.db import
models class BookInfo(models.Model): btitle = models.CharField(max_length=20) bpub_date = models.DateTimeField() class HeroInfo(models.Model): hname = models.CharField(max_length=10) hgender = models.BooleanField() hcontent = models.CharField(max_length=1000) hbook = models.ForeignKey('
BookInfo', on_delete=models.CASCADE) #不加on_delete=models.CASCADE可能會出現__init__() missing 1 required positional argument: 'on_delete'問題

可以執行看一下

生成資料表

  • 啟用模型:編輯settings.py檔案,將booktest應用加入到installed_apps中

  • 生成遷移檔案:根據模型類生成sql語句
python manage.py makemigrations

 
  • 遷移檔案被生成到應用的migrations目錄
  • 執行遷移:執行sql語句生成資料表
python manage.py migrate

測試資料操作

  • 進入python shell,進行簡單的模型API練習
python manage.py shell
  • 新建圖書資訊:
b = BookInfo()
b.btitle="aaa"
b.bpub_date=datetime(year2018,month=12,day=16)
b.save()

  • 查詢所有圖書資訊:
BookInfo.objects.all()

重新編輯models.py,加上一個__str__()方法
from django.db import models


class BookInfo(models.Model):
    btitle = models.CharField(max_length=20)
    bpub_date = models.DateTimeField()

    def __str__(self):  # 不用遷移
        return self.btitle # 列印圖書名字class HeroInfo(models.Model):
    hname = models.CharField(max_length=10)
    hgender = models.BooleanField()
    hcontent = models.CharField(max_length=1000)
    hbook = models.ForeignKey('BookInfo', on_delete=models.CASCADE)

ctrl+d  退出shell

python manage.py shell 重新進入shell

  • 查詢圖書資訊:
b=BookInfo.objects.get(pk=1)

  • 刪除圖書資訊:
b.delete()

關聯物件的操作

  • 對於HeroInfo可以按照上面的操作方式進行
  • 新增,注意新增關聯物件
h=HeroInfo()
h.htitle=u'郭靖'
h.hgender=True
h.hcontent=u'降龍十八掌'
h.hBook=b
h.save()
  • 獲得關聯集合:返回當前book物件的所有hero
b.heroinfo_set.all()
  • 有一個HeroInfo存在,必須要有一個BookInfo物件,提供了建立關聯的資料:
h=b.heroinfo_set.create(htitle=u'黃蓉',hgender=False,hcontent=u'打狗棍法')
h