Django(part22)--創建數據對象

學習筆記,僅供參考,有錯必糾



數據庫的操作(CRUD操作)


CRUD是指在做計算處理時的增加(Create)、讀取查詢(Read)、更新(Update)和刪除(Delete)


管理器對象


每個繼承自 models.Model 的模型類,都會有一個objects對象被同樣繼承下來。這個對象叫管理器對象,數據換的增刪改查可以通過模型的管理器實現。


創建數據對象


Django使用一種直觀的方式把數據庫表中的數據表示成Python對象,創建數據中每一條記錄就是創建一個數據對象

  • 創建方法1
Entry.objects.create(屬性1=1, 屬性2=1,...)
//舉個例子
models.Book.objects.create(title = "django", pub = "清華")

返回值爲已經創建完成的實體對象


  • 創建方法2

創建 Entry 實體對象,並調用 save() 進行保存

obj = Entry(屬性=,屬性=)
obj.屬性=值
obj.save()
//舉個例子
abook = models.Book(title='Python', pub='清華大學出版社')
abook.save()

無返回值,保存成功後,obj對象會被重新賦值

  • 創建方法3
obj = Entry()
obj.屬性=值
obj.save()
//舉個例子
abook = models.Book()
abook.title='R語言'
abook.pub='中國電力出版社'
abook.save()

舉個例子


我們用以前的BLOG數據庫和模型創建的工程mywebsite_db來完成這個例子。

首先我們在bookstore下創建一個urls.py文件,並敲入以下代碼:

from django.urls import re_path
from . import views

urlpatterns = [
    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 include

urlpatterns = [
    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!

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章