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

如何解决在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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?