1. 程式人生 > >django的入門-----設計介紹

django的入門-----設計介紹

需要 增長 elf 執行sql util %d get img ()

設計介紹

  • 本示例完成“圖書-英雄”信息的維護,需要存儲兩種數據:圖書、英雄
  • 圖書表結構設計:
    • 表名: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()
    def _ _str_ _(self):
        return "%d" % self.pk

class HeroInfo(models.Model):
    hname = models.CharField(max_length=20)
    hgender = models.BooleanField()
    hcontent = models.CharField(max_length=100)
    hBook = models.ForeignKey(‘BookInfo‘)
    def _ _str_ _(self):
        return "%d" % self.pk

生成數據表

  • 激活模型:編輯settings.py文件,將booktest應用加入到installed_apps中

技術分享圖片

  • 生成遷移文件:根據模型類生成sql語句
python manage.py makemigrations
  • 遷移文件被生成到應用的migrations目錄

技術分享圖片

  • 執行遷移:執行sql語句生成數據表
python manage.py migrate

測試數據操作

  • 進入python shell,進行簡單的模型API練習
python manage.py shell
  • 進入shell後提示如下:

技術分享圖片

  • 引入需要的包:
from booktest.models import BookInfo,HeroInfo
from django.utils import timezone
from datetime import *
  • 查詢所有圖書信息:
BookInfo.objects.all()
  • 新建圖書信息:
b = BookInfo()
b.btitle="射雕英雄傳"
b.bpub_date=datetime(year=1990,month=1,day=10)
b.save()
  • 查找圖書信息:
b=BookInfo.objects.get(pk=1)
  • 輸出圖書信息:
b
b.id
b.btitle
  • 修改圖書信息:
b.btitle=u"天龍八部"
b.save()
  • 刪除圖書信息:
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的入門-----設計介紹