Django之圖書管理系統

来源:https://www.cnblogs.com/panda-pandeyong/archive/2018/10/07/9718939.html
-Advertisement-
Play Games

通過圖書管理系統學習:一對一,一對多,多對多的操作 文件上傳 ...


 

 

 

 

 

出版社的增刪改查

 展示出版社列表: 

  1. 創建一個表結構:

  

  

    2. 再配合那倆條命令即可創建一個press表

    

 

  創建出版社函數,併在url中進行配置

    

 

  創建HTML頁面,展示出版社的表

    for迴圈

    {% for i in ret %}  ---- 模板語言
    i 指的是 從 ret 中拿到的對象
    {{ forloop.counter }} --> for迴圈從1開始計數
    {{ forloop.counter0 }} --> for迴圈從0開始計數
    {% endfor %}

    

  

 添加出版社(在原表中添加)

  要添加出版社,先跳轉到添加頁面,

    創建添加出版社函數(在url中配置好):

    

     

      創建添加頁面

       把頁面輸入的信息以post的方式提交一個字典,封裝到name鍵

      值中,最終傳給press_add

        

 

      添加完成並展示:

      

      還可以在出版社列表頁面建立 a 標簽,點擊即可跳轉添加頁面

        

 

  刪除出版社:

    在出版社列表中添加刪除操作,點擊刪除項,把要刪除的該項在資料庫

    中刪除.

    在出版社列表的html頁面中標明點擊''刪除''請求後,接收請求的對象.

      

 

    創建刪除出版社的函數:

     即創建接收請求的函數,對該請求做出處理.

    

 

   編輯出版社

     修改原有出版社的信息,在原有列表上添加'編輯'選項,點擊該選項

    跳轉到編輯頁面.

   創建編輯出版社的函數(並完成配置)

    在函數中修改並同步資料庫

    

 

   創建編輯的HTML頁面

  

 

圖書的增刪改查

  在資料庫中創建圖書的列表:

    在models中創建圖書的表結構的類

    通過那倆個命令在資料庫中創建表 

     

 

    創建對書列表進行操作的函數(併在url中配置好)

      

 

    創建在前端展示的html頁面

    

 

     註意: 在函數中對錶進行操作,需要通過ORM語言編寫的表結構類,來獲

    取表的信息

    

      輸出的Press object 對象是通過外鍵獲取的出版社對象

     還可以列印出出版社名字: print(data[0].press.name)

    

      此外 data[0].press_id 可以查詢到與這本書相關聯的出版社id 是通過外鍵查詢的,在

      類中創建表結構過程中,創建外鍵會自動在資料庫中創建外鍵關聯id,此時的外

       鍵id就在本表中.

        

      data[0].press.id 也可以查詢到與這本書相關聯的出版社id 是通過連表查詢的,

       .press是出版社的對象, .id自然能夠獲取到與data[0]相關的出版社id.

 

    添加書籍

    創建添加書籍的操作函數(在url中配置好)

      

        (註意: 上圖name錯誤,表結構中 書籍的名字標題是title)

    創建添加頁面

      

 

   刪除書籍

    在書籍列表中添加刪除操作項,點擊操作項跳轉帶刪除函數進行刪除操作.

    創建要刪除書籍的操作函數

    

    

   編輯書籍

    在書籍頁面中,添加編輯操作的選項,選中要編輯的書籍對象,跳轉頁面進

    行修改,然後保存.

    創建編輯書籍的操作函數(並配置好):

    

      註意 : 末尾的 'return' 表示當還未進行信息編輯時,需要先跳轉到編輯頁面,依照選定好的對

        象進行信息的編輯,編輯完成後,提交.

    

    創建編輯頁面:

    

 

   作者的曾刪改查(多對多)

    作者可以寫多本書,一本書也可以有多個作者.

    創建作者和書的關係

      方法一:        

# 作者:
class Author(models.Model):
    id = models.AuthorField(primary_key=True) # 自增id主鍵
    name = models.CharField(max_length=32) # 作者名字



# 創建作者和書籍的關係表
class Author2Book(models.Model):
    id = models.AuthorField(primary_key=True)
    author = models.Foreignkey(to='Author', on_delete=models.CASCADE)
    book = models.Foreignkey(to='Book', on_delete=models.CASCADE)

 

       方法二 (用orm創建)     

class Author(models.Model):
    id = models.AuthorField(primary_key=True) # 自增id主鍵
    name = models.CharField(max_length=32) # 作者名字
    books = models.ManyToManyField(to='Book')

    

 

   查詢  在資料庫中找到所有作者信息,然後在頁面展示出來

    創建作者函數並配置好

    

    

      創建html文件在頁面上展示出來

      

      

   

    添加  創建添加操作的函數,展示添加頁面,獲取用戶的添加信息,返回給

    資料庫,再展示作者信息.

      創建添加操作的函數,並配置好

    

    創建獲取信息的頁面

    

 

    刪除和編輯

     在作者列表中添加刪除操作項,鎖定要刪除的對象,

      

 

       創建要刪除的操作函數,

    

 

    在作者列表中添加編輯操作,鎖定要編輯的對象

      

 

      創建編輯函數,並配置好:

    

 

    創建html頁面,展示編輯頁面並獲取用戶填寫的信息

    

 

       註意: 模板語言, in 判斷  {% if book in author.books.all %}  意為該

      書在作者所關聯的書籍列表中的話.

      ORM 編輯多對多不能直接編輯第三張表,要藉助ORM提供的方法:

        all()  ; add(id1, id2);  set([id1, id2]);  clear()清空

 

上傳文件

    創建上傳文件的操作函數,並配置好

    

     

 

  創建上傳文件的html頁面      

     enctype="multipart/form-data" 是文件操作必須要有的

 

    

 

 

 

    

    

 

 

 

 

 

 

 

 

    

 

     

 

 

 

 

  

   


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • DIP依賴倒置原則:系統架構時,高層模塊不應該依賴於低層模塊,二者通過抽象來依賴依賴抽象,而不是細節 貫徹依賴倒置原則,左邊能抽象,右邊實例化的時候不能直接用抽象,所以需要藉助一個第三方 高層本來是依賴低層,但是可以通過工廠(容器)來決定細節,去掉了對低層的依賴 IOC控制反轉:把高層對低層的依賴, ...
  • '''#左右手交換牌 案列#小明手裡有倆張牌,左手紅桃♥K,右手黑桃♠A,小明交換倆手的牌後,手裡分別是什麼?人類: 屬性:小明,左手,右手 行為:展示手裡的牌, 交換手裡的牌手類: 屬性:牌 行為:手裡拿著撲克牌牌類: 屬性:顏色,數字(紅桃♥K ,黑桃♠A)思路: 先找到對象:左手,右手,♥K, ...
  • 前言 開心一刻 開學了,表弟和同學因為打架,老師讓他回去叫家長。表弟硬氣的說:不用,我打得過他。老師板著臉對他說:和你打架的那位同學已經回去叫家長了。表弟猶豫了一會依然硬氣的說:可以,兩個我也打得過。老師:...... 路漫漫其修遠兮,吾將上下而求索! github:https://github.c ...
  • 在上一章中我們學習了《MyBatis學習總結(一)——ORM概要與MyBatis快速起步》,這一章主要是介紹MyBatis核心配置文件、使用介面+XML實現完整數據訪問、輸入參數映射與輸出結果映射等內容。 一、MyBatis配置文件概要 MyBatis核心配置文件在初始化時會被引用,在配置文件中定義 ...
  • 1.連接到資料庫: · 面向對象的方法: $db = new mysqli('hostname', 'username', 'password', 'dbname'); · 面向過程的方法: $db = mysqli_connect('hostname', 'username', 'password ...
  • pass ...
  • 單例模式 單例模式(Singleton Pattern)是一種常用的軟體設計模式,該模式的主要目的是確保某一個類只有一個實例存在。當你希望在整個系統中,某個類只能出現一個實例時,單例對象就能派上用場。 比如,某個伺服器程式的配置信息存放在一個文件中,客戶端通過一個 AppConfig 的類來讀取配置 ...
  • 實驗1 用a指令寫入代碼 用t指令單步執行 實驗2 用a指令寫入並修改cs值 用t運行並指定運行17(11H)次,(其實16次(10H)就夠了) 實驗3 d指令查看 得是92年1月1日生產的(很明顯是假的) 嘗試修改 發現並沒有什麼卵用,查了一下,因為這裡是ROM 實驗4 先照例嘗試 發現會在右上角 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...