1

我需要为我的 Flask 应用程序实现一个 API,并且已经看到了针对 Flask-Restless. 我遇到了这个库的基本用法,并希望使用它的人可以提供帮助。

创建 API 管理器和端点...

manager = APIManager(app, flask_sqlalchemy_db=db)
manager.create_api(Gallery, methods=['GET', 'POST', 'PUT', 'DELETE'])

...以及随之而来的模型

class Gallery(db.Model):
    __tablename__ = 'galleries'
    id = db.Column(db.Integer, primary_key=True)

    title = db.Column(db.String(25))

    def __init__(self, title):
        self.title = title

现在,为了插入新条目,我使用了这个 jQuery ajax POST 请求。这工作正常。我已经在 sqlite db 查看器中对其进行了测试,并且可以看到条目。

$('#form').on('submit', function(e){
        $.ajax({
            type: 'post',
            url: '/api/galleries',
            contentType:"binary/octet-stream",
            data: JSON.stringify({'title': $('#title').val()}),
            success: function(){
                alert('Success!');
            }
        });
        e.preventDefault();
    });

这就是问题所在。我进入http://localhost:5000/api/galleries浏览器并收到以下消息:

sqlalchemy.orm.exc.NoResultFound
NoResultFound:没有找到一个()的行

api/galleries奇怪的是,它会在应该返回数据库条目列表时尝试运行 one() 。我尝试api/galleries/1得到完全相同的错误。我仔细检查了一下,主 ID 是 1。我错过了什么?

4

1 回答 1

1

我今天遇到了同样的问题,并通过一些解决方法解决了它。

这是我的模型的样子:

    class User(db.Model):
        id = db.Column(db.Integer, primary_key=True)
        ...

    class Key(db.Model):
        user_id = db.Column(db.Integer, db.ForeignKey('auth_user.id'))
        user = db.relationship('User', backref=db.backref('keys', lazy='dynamic'))
        ...

原因:

查询时收到相同的错误消息users。我发现 flask-restless 正在尝试查询keys我的相关信息users,不幸的是,我的key表是空的,我收到了错误消息。

解决方法:

创建 API 时使用include_columnsexclude_columns排除列:keys

    api_mgr.create_api(User, include_columns = ['email', 'username'])

或者:

    api_mgr.create_api(User, exclude_columns = ['keys', 'SOME_OTHER_COLUMNS'])

您可以检查是否有任何相关表导致问题。如果是原因,您可以使用include_columnsexclude_columns关键字参数。

于 2013-01-04T17:58:55.947 回答