django-models 資料庫取值

来源:https://www.cnblogs.com/ago-0912/archive/2018/11/03/9899559.html
-Advertisement-
Play Games

1 django.shortcuts import render,HttpResponse 2 from app01.models import * 3 # Create your views here. 4 5 def index(request): 6 return render(request... ...


  1 django.shortcuts import render,HttpResponse
  2 from app01.models import *
  3 # Create your views here.
  4 
  5 def index(request):
  6     return render(request,"index.html")
  7 
  8 def addbook(request):
  9     # 一對多的添加
 10 
 11 
 12 
 13     # 第一種方式
 14     # Book.objects.create(name="Linux運維",price=1133,pub_date="2017-11-22",publish_id=2)
 15 
 16 
 17 
 18     # 第二種添加方式 publish_id,沒辦法添加publish_obj
 19     # publish_obj=Publish.objects.filter(name="人民出版社")[0]
 20     # print("+++!!!****",publish_obj)
 21     # +++!!!**** Publish object (1)
 22     # print(type(publish_obj))
 23     # <class 'app01.models.Publish'>
 24 
 25     # Book.objects.create(name="GO語言", price=43, pub_date="2017-07-17", publish_id=2)
 26     # INSERT INTO `app01_book` (`name`, `price`, `pub_date`, `publis
 27     # h_id`) VALUES ('GO語言', 43, '2017-07-17', 2); args=['GO語言', 43, '20
 28     # 17-07-17', 2]
 29 
 30 
 31 
 32     # 拿到資料庫裡面的表的值,有兩步,先拿到值,再賦給對象
 33     # 再從裡面取值
 34     # 先拿到book表,取到name=python的值,再賦給對象
 35     # 如果是兩個值,會報錯,get只能得到一個值
 36     # book_obj=Book.objects.get(name='python')
 37     #
 38     # print("----",book_obj)
 39 
 40 
 41 
 42     # 一對多:book_obj.publish------一定是一個對象
 43     # 如果是要取外鍵的表的值,取publish會取到一個publish對象
 44     # print(type(book_obj.publish))
 45     # print(book_obj.publish.name)
 46     # print(book_obj.publish.city)
 47 
 48 
 49 
 50     # 從子表去找主表
 51     # 要拿到表中外鍵的表的值,步驟有
 52     # 先拿到publish表是name的值等於機械出版社的一整行對象pub_obj(表中有id,name,city)
 53     # SELECT `app01_publish`.`id`, `app01_publish`.`name`, `app01_pu
 54     # blish`.`city` FROM `app01_publish` WHERE `app01_publish`.`name` = '機
 55     # 械出版社'; args=('機械出版社',)
 56     # 把pub_obj結果賦值給publish,由id作為查找依據,再從book表中找到要查詢的name跟price
 57     # SELECT `app01_book`.`name`, `app01_book`.`price` FROM `app01_b
 58     # ook` WHERE `app01_book`.`publish_id` = 4  LIMIT 21; args=(4,)
 59 
 60     # get查找方式:表.objects.get()--只能有一個對象
 61     # pub_obj=Publish.objects.get(name='機械出版社')
 62 
 63     # filter查找方式:表.objects.filter()[0]--是對象的集
 64     # pub_obj2=Publish.objects.filter(name="山西出版社")[0]
 65     # print(pub_obj)
 66     # Publish object (4)
 67 
 68     # print(pub_obj.city)
 69     # 上海
 70     # print(pub_obj.id)
 71     # 4
 72 
 73     # 關鍵點:把publish表的對象放進filter裡面篩選,再從裡面values取值
 74     # ret=Book.objects.filter(publish=pub_obj).values("name","price")
 75     # ret2=Book.objects.filter(publish=pub_obj2).values("name","pub_date")
 76 
 77     # print(ret)
 78     # print(ret2)
 79     # 機械出版社出版的書籍跟價格---query對象
 80     # <QuerySet [{'name': 'Java', 'price': 65}, {'name': 'Linux開發', 'price
 81     # ': 1133}, {'name': 'Linux系統', 'price': 133}, {'name': 'Linux伺服器',
 82     #  'price': 133}]>
 83 
 84 
 85 
 86     # 從主表再去找子表
 87     # ,第一步相同,從publish表找到name等於南方出版社,賦值給pub_obj
 88     pub_obj = Publish.objects.filter(name='山西出版社')[0]
 89     # 再從pub_obj裡面找到book_set.all()(book子表的所有內容) 是一個對象集合
 90 
 91     # publish表拿到了book表的對象,表名+單引號,得到了表名裡面的queryset對象.all()的所有值,
 92     # book_set.all(),再從裡面values取值
 93     print(pub_obj.book_set.all())
 94     # <QuerySet [<Book: Django>, <Book: Linux運維>, <Book: sqlyog>, <Book: Linux代碼>, <Book: GO語言>, <Book: GO語言>, <Book: GO語言>, <Book: moring>]>
 95 
 96     print(pub_obj.book_set.all().values("name",'price'))
 97     # <QuerySet [{'name': 'Django', 'price': 45}, {'name': 'Linux運維', 'pri
 98     # ce': 1133}, {'name': 'sqlyog', 'price': 1133}, {'name': 'Linux代碼', '
 99     # price': 133}, {'name': 'GO語言', 'price': 43}, {'name': 'GO語言', 'pri
100     # ce': 43}, {'name': 'GO語言', 'price': 43}, {'name': 'moring', 'price':
101     #  23}]>
102 
103     # 更簡便的第3種方式:
104     ret=Book.objects.filter()

 


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

-Advertisement-
Play Games
更多相關文章
  • JavaScript部分 HTML結構部分 CSS部分 ...
  • 轉載請註明出處:https://www.cnblogs.com/Joanna-Yan/p/9894712.html 項目需求:設備採集到的GPS坐標信息,需提供實時、歷史軌跡的查看功能。這些點坐標除經緯度信息外還攜帶了其它的信息,比如:速度、方向、解狀態等。原始的GPS坐標需要轉換成百度地圖/高德地 ...
  • 一、使用字體一般步驟如下 1、下載字體文件,放置到適當位置 2、配置軟體或網頁參數,讓軟體或者網頁能關聯到新的字體 3、在軟體或網頁中使用新字體 二、網頁中如何使用自定義字體 1、下載文字文件,如:BebasNeue-webfont.ttf文件,放到和網頁同一位置 2、用@font-face進行字體 ...
  • el-upload組件預設情況下上傳多少個文件就會請求多少次上傳介面,如何一次上傳多個文件而不必多次請求上傳介面呢?直接看代碼 html <el-upload :action="actionUrl" :auto-upload="false" :multiple="true" :file-list=" ...
  • 1.安裝jquery npm install jquery --save-dev 2.打開配置文件webpack.base.conf.js 加入'jquery': path.resolve(__dirname, '../node_modules/jquery/src/jquery') //引入jqu ...
  • 今天刷到一道面試題,["1", "2", "3"].map(parseInt)返回的結果是什麼呢?可能大家第一個想到的是 [1,2,3],但是,我可以明確的告訴你,這是結果錯的!真正的答案是 [1,NaN,NaN] 由於map()接收的回調函數可以有3個參數:callback(currentValu ...
  • 對CAP原理的理解 CAP原理按照定義,指的是C(Consistency)一致性,A(Availability)可用性,P(Partition tolerance)分區容錯性在一個完整的電腦系統中三種特性不能同時得到完全滿足。 Consistency((強)一致性):指的是在同一時間點,所有的數據 ...
  • 在某些情況下,登錄流程由一個OpenID提供者或其他方發起,而不是依賴方(RP)。在這種情況下,發起者重定向到RP在發起登錄終結點,RP的請求驗證請求發送到指定的OP。這個發起登錄終結點可以在RP深度鏈接,而不是預設的登錄頁面。RPs支持OpenID Connect Dynamic Client R ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...