- 41
- 0
三张表
其中shelf_grid是中间表,并且不是一个类
shelf_grid = db.Table(
'shelf_grid',
db.Column('shelf_id', db.Integer, db.ForeignKey('plant_shelf.id')),
db.Column('grid_id', db.Integer, db.ForeignKey('plant_grid.id')))
class Grid(BaseModel, db.Model):
__tablename__ = 'plant_grid'
grid_code = db.Column(db.String(3), unique=True, index=True, nullable=False)
row = db.Column(db.Integer, nullable=False)
col = db.Column(db.Integer, nullable=False)
shelf = db.relationship('Shelf',
secondary='shelf_grid',
backref=db.backref('plant_grid', lazy='dynamic'))
class Shelf(BaseModel, db.Model):
__tablename__ = 'plant_shelf'
shelf_code = db.Column(db.String(3), unique=True, index=True,
nullable=False)
total_grid = db.Column(db.Integer, nullable=False)
surplus_grid = db.Column(db.Integer, nullable=False)
这是我使用的SQL语句:
select plant_grid.* from shelf_grid left join plant_grid on plant_grid.id = shelf_grid.grid_id where shelf_grid.shelf_id=1;
要怎么通过Flask-SQLAlchemy执行这条查询语句?
我通过以下代码执行,但是并不是Flask-SQLAlchemy。获得的grid_code是bytes类型的,而我希望获得的是str类型。此外,我还需要使用paginate()。所以使用以下代码实现功能并不是一个好的选择。
result = db.session.execute("select plant_grid.* from shelf_grid "
"left join plant_grid on
plant_grid.id=shelf_grid.grid_id "
"where shelf_grid.shelf_id=1")
for grid in result:
print(grid.grid_code) # print b'001'... 0
打赏
收藏
点击回答
网站公告
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部
