我遇到问题。我不得不这样做查询:OperationalError:(OperationalError)no such column
@app.route('/api/subscriptions/<string:id>', methods=('DELETE',))
@decorators.login_required
def delete_subscription(id):
dbsession = DBSession()
session = Session()
favorit = (dbsession.query(StudentsFavorites)
.filter(Exams.number == str(id))
.filter(StudentsFavorites.exam_id)
.filter(Students.id == StudentsFavorites.student_id)
.filter(Students.id == str(session.get_user_id()))
.delete() )
dbsession.flush()
return jsonify(error=False)
但是,当我做到这一点查询,我得到这个异常:
OperationalError: (OperationalError) no such column: exams.number u'DELETE FROM students_favorites WHERE exams.number = ? AND students_favorites.exam_id AND students.id = students_favorites.student_id AND students.id = ?' ('123123123', 'a24213')
的表非常大,有很多的信息,所以我不能发布所有的。但这个查询工作:
@app.route('/api/subscriptions/<string:id>', methods=('PUT',))
@decorators.login_required
def add_subscription(id):
dbsession = DBSession()
session = Session()
examID = (dbsession.query(Exams.id)
.filter(Exams.number == id).first()
)
favorit=StudentsFavorites(student_id=session.get_user_id(), exam_id=examID.id)
dbsession.add(favorit)
dbsession.flush()
return jsonify(error=False)
短视图表:
table: Exams
rows: id, number (number is the id i put into the function)
table: StudentsFavorites
rows: student_id, exams_id
table: Students
rows: id
我真的不明白,他为什么不找数行中的例外。
编辑:
数据库StudentsFavorites:
class StudentsFavorites(Base):
"""N:M resolve model for the exams to the semester.
"""
__tablename__ = "students_favorites"
student_id = Column(Unicode(255), ForeignKey("students.id"), primary_key=True, autoincrement=False)
exam_id = Column(Integer, ForeignKey("exams.id"), primary_key=True, autoincrement=False)
created_at = Column(DateTime, nullable = False, default = datetime.now)
student = relationship("Students", uselist = False, lazy="joined")
exam = relationship("Exams", uselist=False, lazy="joined")
像这样的事情?我尝试这样做:
(dbsession.query(StudentsFavorites)
.filter(StudentsFavorites.exam.id == str(id))
.filter(StudentsFavorites.student.id == str(session.get_user_id()))
.delete()
)
但得到的错误,该ID没有在考试中存在/学生
非常感谢,我也尝试过这一点,但它没有工作:(任何其他的想法?我稍后再尝试发布tablestructure,但必须把它缩小 –
什么,你是错误从连接开始?还有,你在这里有多对多的关系,所以如果你检查第二个链接的查询,这应该很容易放在一起(假设你的关系放在一起)。 – AlexLordThorsen
如果我像上面的代码那样编辑它,我得到了同样的错误。我编辑了第一篇文章并导入了StudentFavorits表。作为考试表,我认为这有助于多一点。 –