DRF 学习

一、安装DRF

1、pip install djangorestframework -i https://pypi.douban.com/simple

2、pip install pymysql -i https://pypi.douban.com/simple

二、创建Django项目

1、django-admin startproject drfdemo

三、添加rest_framework应用

1、INSTALLED_APPS = [

...

'rest_framework',

]

四、创建模型操作类

1、创建模型操作类

python 复制代码
class Student(models.Model):
    # 模型字段
    name = models.CharField(max_length=100,verbose_name="姓名")
    sex = models.BooleanField(default=1,verbose_name="性别")
    age = models.IntegerField(verbose_name="年龄")
    class_null = models.CharField(max_length=5,verbose_name="班级编号")
    description = models.TextField(max_length=1000,verbose_name="个性签名")

    class Meta:
        db_table="tb_student"
        verbose_name = "学生"
        verbose_name_plural = verbose_name

2、创建数据库 create database students charset=utf8;

3、执行数据迁移 把app01增加到INSTALL_APPS中

4、在__init__.py中增加pymysql做为数据库驱动

import pymysql

pymysql.version_info = (1, 4, 13, "final", 0)

pymysql.install_as_MySQLdb()

5、在setting.py配置文件中设置mysql的账号密码

python 复制代码
    DATABASES = {
   # 'default': {
   #     'ENGINE': 'django.db.backends.sqlite3',
   #     'NAME': BASE_DIR / 'db.sqlite3',
   # }
    'default':{
        'ENGINE':'django.db.backends.mysql',
        'NAME': "students",
        "HOST": "127.0.0.1",
        "PORT": 3306,
        "USER": "root",
        "PASSWORD": "123456"
    }
}

6、终端命令下执行数据迁移

python manage.py migrate #创建表结构

python manage.py makemigrations app01#让Django知道模型有一些变更 注意是app01 应用名称,不是项目名称

python manage.py migrate app01 #创建表结构 注意是app01 应用名称,不是项目名称

7、在app01中新建serializers.py用于保存应用的序列化器。

创建序列化器类,回头会在试图中被调用 创建一个StudentModelSerializer用于序列化与反序列化。

python 复制代码
    class StudentModelSerializer(serializers.ModelSerializer):
            class Meta:
                    model = Student
                    fields = "__all__"

8、编写视图类

在app01应用的views.py中创建视图StudentViewSet,这是一个视图集合。

python 复制代码
    from django.shortcuts import render
    from rest_framework.viewsets import ModelViewSet
    from .models import Student
    from .serializers import StudentModelSerializer


    # Create your views here.
    class StudentViewSet(ModelViewSet):
            queryset = Student.objects.all()
            serializer_class = StudentModelSerializer

#queryset 指明该视图集在查询数据时使用的查询集

#serializer_class 指明该视图在进行序列化或反序列化时使用的序列化器9、定义路由

新建urls.py 添加路由信息

python 复制代码
    from . import views
    from rest_framework.routers import DefaultRouter

    #路由列表
    urlpatterns = []

    router = DefaultRouter() #可以处理视图的路由
    router.register('student',views.StudentViewSet) #像路由器中注册视图集

    urlpatterns += router.urls  #将路由器中的所有路由追加到django的路由列表中

    把students子应用中的路由文件加载到总路由中
    
    from django.contrib import admin
    from django.conf.urls import url
    from django.urls import path
    from django.urls import include
    from . import  views

    urlpatterns = [
            #path('admin/', admin.site.urls),
            #url(r'^$',views.hello),
            path('',views.hello), #http://127.0.0.1:8000/hello/
            path('print',views.print),  #http://127.0.0.1:8000/print
            path('templates',views.templates),
            path("stu/",include("app01.urls")),
    ]

点击链接127.0.0.1:8000/stu/students获取所有数据

相关推荐
Albert Edison4 小时前
【Python】学生管理系统
开发语言·数据库·python
love530love6 小时前
【ComfyUI】解决 ModuleNotFoundError: No module named ‘inference_core_nodes‘ 问题
人工智能·windows·python·comfyui·inference-core
宇木灵7 小时前
C语言基础-十、文件操作
c语言·开发语言·学习
heimeiyingwang8 小时前
企业供应链 AI 优化:需求预测与智能调度
大数据·数据库·人工智能·机器学习
亚亚的学习和分享8 小时前
python基础语法----条件语句
python
山岚的运维笔记8 小时前
SQL Server笔记 -- 第73章:排序/对行进行排序
数据库·笔记·后端·sql·microsoft·sqlserver
XLYcmy9 小时前
智能体大赛 目录
数据库·ai·llm·prompt·agent·检索·万方
盟接之桥9 小时前
盟接之桥EDI软件:API数据采集模块深度解析,打造企业数据协同新引擎
java·运维·服务器·网络·数据库·人工智能·制造
Zzz 小生9 小时前
LangChain Streaming-Overview:流式处理使用完全指南
人工智能·python·语言模型·langchain·github
yzx9910139 小时前
Python数据结构入门指南:从基础到实践
开发语言·数据结构·python