Django(part22)--创建数据对象
學(xué)習(xí)筆記,僅供參考,有錯必糾
數(shù)據(jù)庫的操作(CRUD操作)
CRUD是指在做計算處理時的增加(Create)、讀取查詢(Read)、更新(Update)和刪除(Delete)
管理器對象
每個繼承自 models.Model 的模型類,都會有一個objects對象被同樣繼承下來。這個對象叫管理器對象,數(shù)據(jù)換的增刪改查可以通過模型的管理器實現(xiàn)。
創(chuàng)建數(shù)據(jù)對象
Django使用一種直觀的方式把數(shù)據(jù)庫表中的數(shù)據(jù)表示成Python對象,創(chuàng)建數(shù)據(jù)中每一條記錄就是創(chuàng)建一個數(shù)據(jù)對象
- 創(chuàng)建方法1
返回值為已經(jīng)創(chuàng)建完成的實體對象
- 創(chuàng)建方法2
創(chuàng)建 Entry 實體對象,并調(diào)用 save() 進(jìn)行保存
obj = Entry(屬性=值,屬性=值) obj.屬性=值 obj.save() //舉個例子 abook = models.Book(title='Python', pub='清華大學(xué)出版社') abook.save()無返回值,保存成功后,obj對象會被重新賦值
- 創(chuàng)建方法3
舉個例子
我們用以前的BLOG數(shù)據(jù)庫和模型創(chuàng)建的工程mywebsite_db來完成這個例子。
首先我們在bookstore下創(chuàng)建一個urls.py文件,并敲入以下代碼:
from django.urls import re_path from . import viewsurlpatterns = [re_path(r'^$', views.bookHome),re_path(r'^add/$', views.addBook), ]在bookstore應(yīng)用的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')) ]我們再回顧一下等下要被添加數(shù)據(jù)的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)現(xiàn)在我們開啟服務(wù),并向http://127.0.0.1:8000/book/發(fā)起請求:
再向http://127.0.0.1:8000/book/add?title=Djangoweb開發(fā)實戰(zhàn)&pub=清華大學(xué)出版社發(fā)起請求
再次查看mywebdb數(shù)據(jù)庫中的bookstore_book表:
mysql> select * from bookstore_book; +----+-------------------+----------------+ | id | title | pub | +----+-------------------+----------------+ | 1 | Djangoweb開發(fā)實戰(zhàn) | 清華大學(xué)出版社 | +----+-------------------+----------------+ 1 row in set (0.00 sec)OK!
總結(jié)
以上是生活随笔為你收集整理的Django(part22)--创建数据对象的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Django(part21)--mode
- 下一篇: Django(part23)--Djan