Django筆記入門小項目
阿新 • • 發佈:2018-12-16
required 通過 obj length ngs 兩種 color test shell
設計介紹
- 本示例完成“圖書-英雄”信息的維護,需要存儲兩種數據:圖書、英雄
- 圖書表結構設計:
- 表名: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
Django筆記入門小項目