學習筆記,僅供參考,有錯必糾
數據庫的操作(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!