Django(part22)--创建数据对象
生活随笔
收集整理的這篇文章主要介紹了
Django(part22)--创建数据对象
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
學習筆記,僅供參考,有錯必糾
數據庫的操作(CRUD操作)
CRUD是指在做計算處理時的增加(Create)、讀取查詢(Read)、更新(Update)和刪除(Delete)
管理器對象
每個繼承自 models.Model 的模型類,都會有一個objects對象被同樣繼承下來。這個對象叫管理器對象,數據換的增刪改查可以通過模型的管理器實現。
創建數據對象
Django使用一種直觀的方式把數據庫表中的數據表示成Python對象,創建數據中每一條記錄就是創建一個數據對象
- 創建方法1
返回值為已經創建完成的實體對象
- 創建方法2
創建 Entry 實體對象,并調用 save() 進行保存
obj = Entry(屬性=值,屬性=值) obj.屬性=值 obj.save() //舉個例子 abook = models.Book(title='Python', pub='清華大學出版社') abook.save()無返回值,保存成功后,obj對象會被重新賦值
- 創建方法3
舉個例子
我們用以前的BLOG數據庫和模型創建的工程mywebsite_db來完成這個例子。
首先我們在bookstore下創建一個urls.py文件,并敲入以下代碼:
from django.urls import re_path from . import viewsurlpatterns = [re_path(r'^$', views.bookHome),re_path(r'^add/$', views.addBook), ]在bookstore應用的views.py模塊中加入以下代碼:
from django.shortcuts import render from django.http import HttpResponse from . import models# Create your views here.def bookHome(request):return HttpResponse("<h1>Welcome to BookStore!</h1>")def addBook(request):if request.method == 'GET':title = request.GET.get('title', 'noname')publish = request.GET.get('title', 'nopublisher')models.Book.objects.create(title = title, pub = publish)return HttpResponse("<h1>Good!</h1>")接下來,我們在主urls.py文件中敲入以下代碼:
from django.contrib import admin from django.urls import path from django.urls import re_path from django.conf.urls import includeurlpatterns = [path('admin/', admin.site.urls),re_path(r'^book/', include('bookstore.urls')) ]我們再回顧一下等下要被添加數據的bookstore_book表:
mysql> desc bookstore_book; +-------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+----------------+ | id | int(11) | NO | PRI | NULL | auto_increment | | title | varchar(30) | NO | | NULL | | | pub | varchar(50) | YES | | NULL | | +-------+-------------+------+-----+---------+----------------+ 3 rows in set (0.01 sec)mysql> select * from bookstore_book; Empty set (0.01 sec)現在我們開啟服務,并向http://127.0.0.1:8000/book/發起請求:
再向http://127.0.0.1:8000/book/add?title=Djangoweb開發實戰&pub=清華大學出版社發起請求
再次查看mywebdb數據庫中的bookstore_book表:
mysql> select * from bookstore_book; +----+-------------------+----------------+ | id | title | pub | +----+-------------------+----------------+ | 1 | Djangoweb開發實戰 | 清華大學出版社 | +----+-------------------+----------------+ 1 row in set (0.00 sec)OK!
總結
以上是生活随笔為你收集整理的Django(part22)--创建数据对象的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Django(part21)--mode
- 下一篇: 2022小班新年祝福语简短创意