首頁 > 軟體

python Django實現增刪改查實戰程式碼

2022-02-19 13:00:39

1.先建立個app子級

python .manage.py startapp app01

然後建立資料模型

app01下的
modules.py檔案

from django.db import models

# Create your models here.
class UserInfo(models.Model):
    name=models.CharField(max_length=32)
    password=models.CharField(max_length=12)
    age=models.IntegerField()
    tel=models.IntegerField(max_length=11)

設定資料庫

'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': '資料庫名',
        'USER': '資料庫使用者名稱',
        'PASSWORD': '密碼',
        'HOST': '127.0.0.1',
        'PORT': '3306',
    }

2.遷移資料庫

python manage.py makemigrations 和 python manage.py migrate

3.寫路由url

from django.contrib import admin
from django.urls import path,include
from app01 import views
urlpatterns = [
    # path('admin/', admin.site.urls),
    # path('index/',views.index),
    # path('user/list/', views.user_list),
    # path('login/', views.ApiLogin.as_view()),
    # path('del/', views.ApiDel.as_view()),
    path('add/', views.addUser.as_view()),
    path('user/', views.UserList.as_view()),
    path('updateuser/', views.upDateUser.as_view()),
    path('del/', views.deluser.as_view()),
]

4.view頁面編寫增刪改查

from django.shortcuts import render,HttpResponse
from rest_framework.views import APIView
# Create your views here.
from django import views
from app01.models import UserInfo
from rest_framework.response import Response
from app01.ser import APIViewUserInfo
class addUser(APIView):
    def post(self,request):
        obj=APIViewUserInfo(data=request.data)
        if obj.is_valid():
            obj.save()
            return Response({"data":obj.data, "status" : 201,"message":"新增使用者成功"})
        return Response(data=obj.errors,status=400)
class UserList(APIView):
    def get(self,request):
        obj=UserInfo.objects.all()
        ser=APIViewUserInfo(instance=obj,many=True)
        return Response(ser.data)
class upDateUser(APIView):
    def post(self,request):
        print(request.data.get('id'))
        i=request.data.get('id')
        try:
            user=UserInfo.objects.get(id=i)
        except Exception as e:
            return Response(data='不存在', status=201)
        # 建立序列化物件,並將要反序列化的資料傳遞給data構造引數,進而進行驗證
        user.password=request.data.get('password')
        if request.data.get('name')!='':
            print(request.data.get('name')=='')
            user.name=request.data.get('name')
        user.save()
        return Response(status=400)
class deluser(APIView):
    def post(self,request):
        id=request.data.get('id')
        UserInfo.objects.filter(id=id).delete()
        return Response({"msg":'刪除成功',"state":"true"})
# def index(request):
#     return HttpResponse("歡迎使用")
#
#
# def user_list(request):
#     return render(request,"user_list.html")
#
# class ApiLogin(APIView):
#     def get(self,request):
#         return HttpResponse('get')
#     def post(self,request):
#         UserInfo.objects.create(name='張三',password='123456',age=15,tel='1234567891')
#         obj=UserInfo.objects.all()
#         print(obj)
#         return HttpResponse('post')
#
# class ApiDel(APIView):
#     def post(self,request):
#         UserInfo.objects.filter(id=4).delete()
#         return HttpResponse('刪除成功')

5.序列化 反序列化

# -*- coding: utf-8 -*-
from rest_framework import serializers
from app01.models import UserInfo
class APIViewUserInfo(serializers.Serializer):
    """圖書資料序列化器"""
    id = serializers.IntegerField(label='ID', read_only=True)       # 主鍵序列化
    # 第一:普通欄位序列化
    name = serializers.CharField(label='名稱', max_length=20)
    password = serializers.CharField(label='密碼')
    age = serializers.IntegerField(label='年齡', required=False)
    tel = serializers.IntegerField(label='電話', required=False)
    # # 第二:一對多欄位序列化
    # heroinfo_set = serializers.PrimaryKeyRelatedField(read_only=True, many=True)
    # # 第三:自定義顯示(顯示多對多)
    # xxx = serializers.SerializerMethodField(read_only=True)
    class Meta:
        model = UserInfo
    # 自定義顯示 多對多 欄位
 # 定義建立語法:ser.save()執行,就會立刻呼叫create方法用來建立資料
    def create(self, validated_data):
        '''validated_data: 表單或者vue請求攜帶的json:{"username":"zhangsan","password":"123456"}'''
        return self.Meta.model.objects.create(**validated_data)

到此這篇關於python Django增刪改查 快速體驗的文章就介紹到這了,更多相關python Django增刪改查內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com