小编给大家分享一下Django开发RESTful API怎么实现增删改查,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
数据库中有user表如下:
新建一个Django项目:
django-admin.py startproject myDjango<project_name>
目录介绍
myDjango/ ├── manage.py # 管理文件 └── myDjango # 项目目录 ├── __ init __.py ├── settings.py # 配置文件 ├── urls.py # 路由 --> URL和函数的对应关系 └── wsgi.py # runserver命令就使用wsgiref模块做简单的web server
使用rest_framework
在setting.py中添加:
INSTALLED_APPS = [ ... 'rest_framework' ]
连接MySQL数据库
在setting.py中设置:
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 # 管理站点模型的声明文件,默认为空 ├── apps.py # 应用信息定义文件。在其中生成了类Appconfig,类用于定义应用名等Meta数据 ├── models.py # 添加模型层数据类的文件 ├── tests.py # 测试代码文件 └── views.py # 定义URL响应函数
在setting.py中添加:
INSTALLED_APPS = [ ... 'users' ]
把数据库中的表生成对应的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'
创建一个序列化Serializer类,使之可以转化为,某种表现形式如json
在users目录下,创建文件serializers.py
from rest_framework import serializers from users.models import User class UserSerializer(serializers.ModelSerializer): class Meta: model = User fields = "__all__"
数据输出
编写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): # 获取全部数据 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): # 根据id查找单条数据 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('请传id')) @api_view(['POST']) def addUser(request): # 添加数据 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): # 根据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('没有此id')) else: return Response(str('请传id')) @api_view(['POST']) def updateUser(request): # 根据id修改数据 if User.objects.filter(id=request.data['id']): user = User.objects.get(id=request.data['id']) ser = UserSerializer(instance=user, data=request.data) # 注意指定参数 if ser.is_valid(): ser.save() return Response(str('success')) return Response(ser.errors) return Response(str('没有此id'))
在urls.py中设置:
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') ]
启动项目:
python manage.py runserver 127.0.0.1:8000
访问结果:
以上是“Django开发RESTful API怎么实现增删改查”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。