flask sqlalchemy filter_by дает ошибку во время выполнения - PullRequest
1 голос
/ 02 февраля 2020

Извините, если вопрос примитивный. Я новичок в Flask и SQL Алхимия.

У меня есть модель, как показано ниже.

class Department(FlaskSerializeMixin,db.Model):
        id = db.Column(db.Integer, primary_key=True)
        dep_name = db.Column(db.String(100),unique=True,nullable=False)
        dep_prefix = db.Column(db.String(1),unique=True,nullable=False)
        cre_time =db.Column(db.DateTime)
        chg_time =db.Column(db.DateTime)

И у меня есть маршрут для редактирования отдела, как показано ниже

@menuOps_bp.route('/edit_dep', methods=['POST'])
def edit_dep():
    req=request.get_json()
    print(req)
    if Department.query.filter_by(id != req['row_id'], dep_name=req['deptName'] ).first() is None:
        if Department.query.filter_by(id != req['row_id'], dep_prefix=req['dPrefix'] ).first() is None:
            dep = Department.query.filter_by(id=req['row_id']).first()
            dep.dep_name=req['deptName']
            dep.dep_prefix=req['dPrefix']
            dep.chg_time = datetime.datetime.now()
            db.session.commit()
            return jsonify({'success':"Department {dep} is update succussfully".format(dep=req['deptName'])})
        else:
            return jsonify({'error' : " The PreFix [ {prefix} ] is already Used !!!".format(prefix=req['dPrefix'])})
    else:
        return jsonify({'error' :  " Department [ {dep} ] is already Used !!!".format(dep=req['deptName'])})

Приложение было запущено правильно, но при вызове маршрута с if Department.query.filter_by(id != req['row_id'], dep_name=req['deptName'] ).first() is None: происходит сбой с приведенной ниже ошибкой. Пожалуйста, помогите решить проблему.

  File "/home/rishthaz/QMS_AIMS/ECQ/ecqenv/lib/python3.7/site-packages/flask/app.py", line 1935, in dispatch_request
    return self.view_functions[rule.endpoint](**req.view_args)
  File "/home/rishthaz/QMS_AIMS/ECQ/v1/BE/menu/routes.py", line 29, in edit_dep
    if Department.query.filter_by(id != req['row_id'], dep_name=req['deptName'] ).first() is None:
**TypeError: filter_by() takes 1 positional argument but 2 were given**

в основном я хочу запустить запрос select count(1) from department where id != <somevalue> and dep_name = <somevalue>

1 Ответ

0 голосов
/ 02 февраля 2020

В вашем случае я бы рекомендовал использовать filter вместо filter_by, причина в том, что вы стремитесь к сравнению, а не в качестве аргумента ключевого слова:

if not Department.query.filter(
         Department.id != req['row_id'], 
         Department.dep_name==req['deptName'] 
    ):
    ### continue...

filter принимает несколько аргументы, и трактует их как and в вашем случае. Кроме того, вы также можете передать and_ или даже позвонить дважды:

if not Department.query\
    .filter(Department.id != req['row_id'])\
    .filter(Department.dep_name==req['deptName']):
    ### continue ...

Настоятельно рекомендуем этот ответ о разнице между filter и filter_by :

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...