在Flask REST API中,我需要创建不同的模型和资源来操纵同一张表的不同行吗?

问题描述

我是API新手,正在创建FLask Restful API。我想知道我是否需要为要在数据库中进行的任何行操作创建新的模型和资源类?例如,我在数据库中创建了一个学生。创建时他没有任何分数,因此我创建了StudentModel和StudentResource并使用了Student表。当我需要使用PUT请求更新成绩时,是否还需要创建一个SudentGradeModel和StudentGradeResource来访问学生表?

每个Model类都包括Resource类通过导入Model类使用的辅助函数。资源类仅具有GET,POST,PUT和DELETE方法

class StudentModel(db.Model):
    __tablename__ = 'Student'
    __table_args__ = {'extend_existing': True}

    id = db.Column(db.Integer,primary_key=True)
    name = db.Column(db.String(30))
    class_sec = db.Column(db.String(4))
    
    def __init__(self,id,name,class_sec):
        self.id = id
        self.name= name
        self.class_sec = class_sec    

from flask_restful import Resource,reqparse

from models.student_model import StudenteModel


# noinspection PyMethodMayBeStatic
class StudentResource(Resource):

    parser = reqparse.RequestParser()
    parser.add_argument('id',type=int,required=True,help='Every Student must have an ID')
    parser.add_argument('name',type=str,help='Every Student must have a name')
    parser.add_argument('class',help='Every Student must be assigned a class and section')

    def get(self,id):
        pass

    def post(self,id):
        pass

class StudentGradeModel(db.Model):
    __tablename__ = 'Student'
    __table_args__ = {'extend_existing': True}

    id = db.Column(db.Integer,primary_key=True)
    grade = db.Column(db.String(2),primary_key=True)
    
    def __init__(self,grade):
        self.id = id
        self.grade = grade
# noinspection PyMethodMayBeStatic
class StudentGradeResource(Resource):

    parser = reqparse.RequestParser()
    parser.add_argument('id',help='Student must have an ID to access table')
    parser.add_argument('grade',help='Student must have a grade to be assigned')

    def get(self,id):
        pass

类似地,如果我只想更新该部分,则必须使用PUT请求创建一个类似的Classe。

谢谢

解决方法

从这个问题出发,我假设一个学生只能获得一个年级或根本没有一个年级,因为如果他们可以有一个以上的年级,那么一个年级必须在单独的表格中。

表创建SQL看起来像这样:

CREATE TABLE student (
  id INT PRIMARY KEY,name VARCHAR(30) NOT NULL,class_sec CHAR(4) NOT NULL,grade INTEGER
);

(由于数值数据不应存储为字符串,因此我更改了成绩的数据类型)


不,您不能,并且不应在同一张表上使用两个模型。该模型应代表表格本身。

class StudentModel(db.Model):
    __tablename__ = 'Student'
    __table_args__ = {'extend_existing': True}

    id = db.Column(db.Integer,primary_key=True)
    name = db.Column(db.String(30),nullable=False)
    class_sec = db.Column(db.String(4),nullable=False)
    grade = db.Column(db.Integer)
    
    def __init__(self,id,name,class_sec):
        self.id = id
        self.name= name
        self.class_sec = class_sec

另一方面,您可以使用多个资源来连接表。但是,每种资源都与一条路线相关联,除非您需要另一条路线(我认为您不需要这样做),否则不应为成绩分配单独的资源。

class Student(Resource):
    ...
    def put(self,id):
        request_body = request.get_json()
        # do your things here