增刪改查是大多數(shù)web應(yīng)用都會(huì)實(shí)現(xiàn)的功能,使用Django開(kāi)發(fā)web應(yīng)用的話(huà)增刪改查的實(shí)現(xiàn)變得更加容易。今天我們就在Django的基礎(chǔ)上,來(lái)創(chuàng)建一個(gè)RESTfulAPI結(jié)果的接口,對(duì)Django的增刪改查和RESTfulAPI相關(guān)知識(shí)做一個(gè)總結(jié)。
數(shù)據(jù)庫(kù)中有user表如下:
新建一個(gè)Django項(xiàng)目:
django-admin.py startproject myDjango<project_name>
目錄介紹
myDjango/ ├── manage.py # 管理文件 └── myDjango # 項(xiàng)目目錄 ├── __ init __.py ├── settings.py # 配置文件 ├── urls.py # 路由 --> URL和函數(shù)的對(duì)應(yīng)關(guān)系 └── wsgi.py # runserver命令就使用wsgiref模塊做簡(jiǎn)單的web server
使用rest_framework
在setting.py中添加:
INSTALLED_APPS = [
...
'rest_framework'
]
連接MySQL數(shù)據(jù)庫(kù)
在setting.py中設(shè)置:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'bigdatatest',
'USER': 'root',
'HOST': '127.0.0.1',
'PASSWORD': '1009',
'PORT': 3306,
'OPTIONS': {'charset': 'utf8mb4'},
}
}
在__init__.py中添加:
import pymysql
pymysql.version_info = (1, 4, 13, "final", 0)
pymysql.install_as_MySQLdb()
新建app
python manage.py startapp users<app_name>
目錄介紹:
users/ ├── migrations # 用于在之后定義引用遷移功能 ├── __ init __.py ├── __ init __.py ├── admin.py # 管理站點(diǎn)模型的聲明文件,默認(rèn)為空 ├── apps.py # 應(yīng)用信息定義文件。在其中生成了類(lèi)Appconfig,類(lèi)用于定義應(yīng)用名等Meta數(shù)據(jù) ├── models.py # 添加模型層數(shù)據(jù)類(lèi)的文件 ├── tests.py # 測(cè)試代碼文件 └── views.py # 定義URL響應(yīng)函數(shù)
在setting.py中添加:
INSTALLED_APPS = [
...
'users'
]
把數(shù)據(jù)庫(kù)中的表生成對(duì)應(yīng)的model
python manage.py inspectdb
將我們表的model拷貝到users下的models.py里
from django.db import models
class User(models.Model):
id = models.IntegerField(primary_key=True)
name = models.CharField(max_length=255, blank=True, null=True)
age = models.IntegerField(blank=True, null=True)
class Meta:
managed = False
db_table = 'user'
創(chuàng)建一個(gè)序列化Serializer類(lèi),使之可以轉(zhuǎn)化為,某種表現(xiàn)形式如json
在users目錄下,創(chuàng)建文件serializers.py
from rest_framework import serializers
from users.models import User
class UserSerializer(serializers.ModelSerializer):
class Meta:
model = User
fields = "__all__"
數(shù)據(jù)輸出
編寫(xiě)users下的views.py
from __future__ import unicode_literals
from rest_framework.decorators import api_view
from rest_framework.response import Response
from user.models import User
from user.serializers import UserSerializer
@api_view(['GET'])
def getlist(request): # 獲取全部數(shù)據(jù)
if request.method == 'GET':
users = User.objects.values('id', 'name', 'age').distinct()
serializer = UserSerializer(users, many=True)
return Response(serializer.data)
@api_view(['GET'])
def getlistpic(request): # 根據(jù)id查找單條數(shù)據(jù)
id = request.GET['id']
if id is not None:
users = User.objects.filter(id=id)
serializer = UserSerializer(users, many=True)
return Response(serializer.data)
else:
return Response(str('請(qǐng)傳id'))
@api_view(['POST'])
def addUser(request): # 添加數(shù)據(jù)
ser = UserSerializer(data=request.data)
if ser.is_valid():
ser.save()
return Response(ser.data)
return Response(ser.errors)
@api_view(['GET'])
def deleteUser(request): # 根據(jù)id添加刪除
id = request.GET['id']
if id is not None:
if User.objects.filter(id=id):
User.objects.get(id=id).delete()
return Response(str('success'))
else:
return Response(str('沒(méi)有此id'))
else:
return Response(str('請(qǐng)傳id'))
@api_view(['POST'])
def updateUser(request): # 根據(jù)id修改數(shù)據(jù)
if User.objects.filter(id=request.data['id']):
user = User.objects.get(id=request.data['id'])
ser = UserSerializer(instance=user, data=request.data) # 注意指定參數(shù)
if ser.is_valid():
ser.save()
return Response(str('success'))
return Response(ser.errors)
return Response(str('沒(méi)有此id'))
在urls.py中設(shè)置:
from django.conf.urls import url
from users import views as users_views
urlpatterns = [
url(r'^getlistpic', users_views.getlistpic, name='home'),
url(r'^getlist', users_views.getlist, name='home'),
url(r'^addUser', users_views.addUser, name='home'),
url(r'^deleteUser', users_views.deleteUser, name='home'),
url(r'^updateUser', users_views.updateUser, name='home')
]
啟動(dòng)項(xiàng)目:
python manage.py runserver 127.0.0.1:8000
訪(fǎng)問(wèn)結(jié)果:
源碼地址: myDjango
參考:
創(chuàng)建第一個(gè)Django項(xiàng)目
Python用Django寫(xiě)restful api接口
到此這篇關(guān)于Django開(kāi)發(fā)RESTful API實(shí)現(xiàn)增刪改查的文章就介紹到這了,更多相關(guān)Django和RESTful API的學(xué)習(xí)內(nèi)容請(qǐng)搜索W3Cschool以前的文章或繼續(xù)瀏覽下面的相關(guān)文章。