Django开发RESTful API实现增删改查(入门级)
作者:乔路非 发布时间:2022-05-17 02:36:53
标签: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
访问结果:
源码地址: myDjango
参考:
创建第一个Django项目
Python用Django写restful api接口
来源:https://blog.csdn.net/qq_40731976/article/details/108823765


猜你喜欢
- 这篇文章主要介绍了python装饰器使用实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以
- Python安装流程:一.下载在网上(输入网址https://www.python.org/downloads/)下载Windows最新的p
- wxPython是Python语言的一套优秀的GUI图形库。允许Python程序员很方便的创建完整的、功能键全的GUI用户界面。wxPyth
- SQL Server 2008支持四种协议,Shared Memory;TCP/IP;Named Pipes和Virtual Interfa
- 一,对应点相乘,x.mul(y) ,即点乘操作,点乘不求和操作,又可以叫作Hadamard product;点乘再求和,即为卷积data =
- 在python中除了print函数之外,len函数和type函数应该算是使用最频繁的API了,操作都比较简单。一.len函数简介返回对象的长
- 我使用的是anaconda。我推荐大家使用anaconda,对环境依赖关系处理的比较好。不用浪费太多时间在安装模块上。首先安装pyinsta
- Python面向对象编程(一)Python面向对象编程(二)Python面向对象编程(三)一、对象的继承Python中支持一个类同时继承多个
- 目录实际项目中遇到的需求有一些不好的实现方式个人感觉比较好的实现方式功能已实现,但我又开始了新的思考最终方案——高阶组件实际项目中遇到的需求
- 前言前面一篇分享了关于数值的一些处理方式,本篇呢进行一下字符串处理的分享 题目也是超级简单,记录一下对字符串处理的方式错位键盘🍓(也就是错位
- 本文实例讲述了python二分查找算法的递归实现方法。分享给大家供大家参考,具体如下:这里先提供一段二分查找的代码:def binarySe
- 在附加数据库后查看不了数据库关系图,也无法建立数据库关系图 我的解决方法如下: 1、设置兼容级别为90(2005为90)(2000为80)
- 本文实例讲述了Python图形绘制操作之正弦曲线实现方法。分享给大家供大家参考,具体如下:要画正弦曲线先设定一下x的取值范围,从0到2π。要
- 本文实例讲述了Python文件与文件夹常见基本操作。分享给大家供大家参考,具体如下:1、判断文件(夹)是否存在。os.path.exists
- 因为编写了一个Python程序,密集的操作了一个Mysql库,之前数据量不大时,没发现很慢,后来越来越慢,以为只是数据量大了的原因,但是后来
- IE(internet explorer)公司:微软(MicroSoft)布局引擎:Trident(也做MSHTML)注:解析渲染
- 小编使用python中的django框架来完成!1,首先用pycharm创建django项目并配置相关环境这里小编默认项目都会创建setti
- 本文实例讲述了c#操作附加数据库的方法。分享给大家供大家参考。具体如下:/// <summary>/// 附加数据库/// &l
- 前文昨天家里来人,老姐的小孩儿抢着跟我玩电脑,result........很久很久之后!!那你想错了,我可不是欺负小孩子的那种人。老实人本人
- 如下所示:<span style="font-family: Arial, Helvetica, sans-serif;&q