- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
给定:
DIRECTIONS = db.Enum('N', 'NE', 'E', 'SE', 'S', 'SW', 'W', 'NW',
name='directions')
class Exit(BaseModel):
__tablename__ = 'exits'
src = db.Column(db.Integer, db.ForeignKey('room.id'), primary_key=True)
dst = db.Column(db.Integer, db.ForeignKey('room.id'), primary_key=True)
direction = db.Column(DIRECTIONS, primary_key=True)
from_room = db.relationship('Room', foreign_keys=[dst],
backref=db.backref('exits',
lazy='dynamic'))
to_room = db.relationship('Room', foreign_keys=[src]))
使用:
SqlAlchemy 0.9.8,PostgreSQL 9.3.5
在给定起始房间 r
的情况下,如何查询以递归方式选择某个深度 n
的导出?
示例(一个简单的 map ):
E
/
B C -- D
\ /
A
|
F
/ \
G H
\
I
假设关系可以用上面的 map 表示,
A
开始,通过将深度限制为 2,选择除 E
和 I
之外的所有房间。当然,我可以用 Python 做到这一点:
rooms = [starting_room]
for exit in starting_room.exits.all():
if exit.to_room not in rooms:
add_to_map(exit)
rooms.append(exit.to_room)
for room in rooms[1:]:
for exit in room.exits.all():
if exit.to_room not in rooms: add_to_map(exit)
rooms.append(exit.to_room)
但这很昂贵,不适合超过 2 跳。
我试过遵循CTE SQLAlchemy 文档中的示例,但很难理解如何使它像我一样适用于关联对象,尤其是因为我没有在纯 SQL 中使用 CTE 的经验。
我的尝试:
>>> starting_exits = db.session.query(Exit).filter_by(from_room=starting_room).came='starting_exits', recursive=True)
>>> start = orm.aliased(starting_exits, name='st')
>>> exit = orm.aliased(Exit, name='e')
>>> cte = starting_exits.union_all(db.session.query(exit).filter(exit.src == start.c.dst))
>>> db.session.query(cte).all()
无限期挂起,即使我对其进行切片 (.all()[:5]
)。我应该做什么?
最佳答案
我希望我没有使您的模型过于复杂,但为了测试查询(如下所示),我使用了以下模型定义:
class Room(Base):
__tablename__ = 'room'
id = Column(Integer, primary_key=True)
name = Column(String)
exits = association_proxy(
'lnk_exits', 'to_room',
# creator=lambda v: Exit(to_room=v),
creator=lambda k, v: Exit(direction=k, to_room=v),
)
entries = association_proxy(
'lnk_entries', 'from_room',
# creator=lambda v: Exit(from_room=v),
creator=lambda k, v: Exit(direction=k, from_room=v),
)
class Exit(Base):
__tablename__ = 'exits'
src = Column(Integer, ForeignKey('room.id'), primary_key=True)
dst = Column(Integer, ForeignKey('room.id'), primary_key=True)
direction = Column(DIRECTIONS, primary_key=True)
from_room = relationship(
Room, foreign_keys=[dst],
# backref='lnk_exits',
backref=backref(
"lnk_exits",
collection_class=attribute_mapped_collection("direction"),
cascade="all, delete-orphan",
)
)
to_room = relationship(
Room,
foreign_keys=[src],
# backref='lnk_entries',
backref=backref(
"lnk_entries",
collection_class=attribute_mapped_collection("direction"),
cascade="all, delete-orphan",
)
)
您确实不需要像我那样使用关系,但我喜欢我这样做的方式,因为它允许我处理房间之间的关系,如下所示:
# Insert test data
rooms = [Room(name=name) for name in 'ABCDEFGHI']
session.add_all(rooms)
A, B, C, D, E, F, G, H, I = rooms
A.entries = {'NW': B, 'NE': C, 'S': F}
B.entries = {'SE': A}
C.entries = {'E': D, 'SW': A}
D.entries = {'W': C, 'NE': E}
E.entries = {'SW': D}
F.entries = {'N': A, 'SW': G, 'SE': H}
G.entries = {'NE': F}
H.entries = {'NW': F, 'SE': I}
if True: # add cycle, in which case we get duplicates in the results
B.entries['E'] = C
C.entries['W'] = B
session.commit()
您可以在 Association Proxy
中阅读更多相关信息文档的一部分。
请注意,为了使用下面的查询,您不需要上面的任何关联代理和相关内容。即使关系简单,当前查询也会挂起 A <--> B
因为你CTE
将无限期地来回导航。所以诀窍是添加 level
信息到CTE
这样您就可以在级别上限制搜索。下面的查询应该让你开始:
# parameters
start_id = session.query(Room).filter(Room.name == 'A').first().id
max_level = 2
# CTE definition
starting_exits = (session.query(Exit, literal(0).label("level"))
.filter(Exit.src == start_id)
.cte(name="starting_exits", recursive=True)
)
start = aliased(starting_exits, name="st")
exit = aliased(Exit, name="e")
joined = (session.query(exit, (start.c.level + 1).label("level"))
.filter(exit.src == start.c.dst)
# @note: below line will avoid simple cycles of 2, which does not always help, but should reduce the result-set significantly already
.filter(exit.dst != start.c.src)
.filter(start.c.level < max_level)
)
cte = start.union_all(joined)
for x in session.query(cte).order_by(cte.c.src, cte.c.dst, cte.c.level):
print(x)
我假设您只对结果查询的第二列 ( dst
) 感兴趣,以便获得 id
的 Room
你可以到达。可能还有第四列 ( level
) 会很有趣,以便找到到那个房间的最短路径。但是您可能仍然有多种方法可以到达同一个目标房间,因此请事后过滤掉这些方法。
编辑: 使用 cte
的简单方法为了获得房间(模型实例)将是:
# get all Rooms (no duplicates)
s = session.query(cte.c.dst.distinct().label("room_id")).subquery(name="rooms")
q = session.query(Room).join(s, Room.id == s.c.room_id)
for r in q:
print(r)
编辑 2:要获取导出和房间(模型实例)以重建图形,只需对上面的查询进行另一个连接:
exits = (session.query(Exit, Room)
.join(s, Exit.dst == s.c.room_id)
.join(Room, Room.id == s.c.room_id))
for exit, room in exits:
print exit, room
关于python - 使用 ORM、声明式样式和关联对象在 SQLAlchemy 中递归选择(深度有限)关系,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28032023/
最近几天,我们考虑使用 Solr 作为我们的首选搜索引擎。 我们需要的大多数功能都是开箱即用的,或者可以轻松配置。 然而,我们绝对需要的一项功能似乎在 Solr 中被很好地隐藏(或缺失)了。 我会试着
我是 Sequelize 的新手,并且一直在探索关联。我正在使用 mysql 5.6 并 Sequelize ^4.42.0。我正在尝试创建两个简单的表:PRJS 和 TASKS 并将一些数据插入这些
关联、聚合和组合之间有什么区别?请从实现的角度解释一下。 最佳答案 对于两个对象,Foo 和 Bar 可以定义关系 关联 - 我与一个对象有关系。 Foo 使用 Bar public class Fo
这两种 hasOne 语法有什么区别? class Project { ....... ............ static hasOne = Employee // static h
对于当前的项目,我想使用遗传算法 - 目前我查看了 jenetics 库。 如何强制某些基因相互依赖?我想将 CSS 映射到基因上,例如我有基因指示是否显示图像,以及如果它也是各自的高度和宽度。因此,
关联、聚合和组合之间有什么区别?请从实现的角度解释一下。 最佳答案 对于两个对象,Foo 和 Bar 可以定义关系 关联 - 我与一个对象有关系。 Foo 使用 Bar public class Fo
假设我有一个名为“学生”的表格,其中包含姓名、手机、电子邮件、首选类(class)、首选学校、性别、年龄、地址、资格、职称、家庭电话、工作电话等列 我想从 Students 表中选择数据并插入到 2
问题标题有点困惑。我有一级员工和一级项目。一名或多名员工正在从事一个或多个项目。在这个关联中,我只有一个从具有*多重性的员工类到具有*多重性的项目类的链接。现在有另一种实现。每个项目只有一名经理,属于
到目前为止,我有一个程序采用一组随机点、站点,并围绕这些点形成适当的 Voronoi 图,表示为角和边的图形。它还为我提供了 Delaunay 三角剖分作为另一个以所有站点为节点的图形(尽管我不知道这
实现IComMethodEvents时你得到三个事件。 OnMethodCall OnMethodException OnMethodReturn 我的目标是记录 COM+ 组件中每个方法的调用时间。
我正在处理这个问题。我正在创造数学问题,每一个都有回应。例如。 如果我的问题是关于“5x + 15 = 2 的结果?”,我将只等待一个答案(整数)。 如果我的问题是关于“给我这个形状的面积和许可”,我
我正在寻找一种数据结构来保存唯一元素的无序集合,它将支持以下操作 在集合中任意位置插入/删除元素 查询元素是否存在 访问一个随机元素 天真地,1 和 2 建议使用关联容器,例如unordered_se
是否可以在 LINQ 中使用类似 ContactAddress.Contact 的内容,而无需在 SQL Server 中在这两者之间创建外键关系(通过 Contact.Id ContactAddr
我一直在谷歌搜索,但不明白调用 javax.persistence.criteria.Subquery 和 Criteria API 的方法相关的结果是什么。 http://www.objectdb.
我正在关注 Chris McCord 的“Programming Phoenix”一书,在第 6 章中,在 User 之间创建了一个关系。和一个 Video . 尝试使用 mix phoenix.se
我在 XAML 中有一个 ItemsControl,我在其中为每个组显示一个扩展器,以便我可以展开/折叠该组。我想保持 IsExpanded 的状态属性(以及可能与组标题显示相关的其他设置)。通常你只
Oracle 11 中是否有内置方法来检查 varchar2 字段中值的相关性?例如,给定一个简单的表,如下所示: MEAL_NUM INGREDIENT --------------------
是否可以在没有 JPA 在数据库中创建外键的情况下设置多对一关联? 这些表归另一个系统所有,并以异步方式填充。因此我们不能在数据库中使用 FK。仍然,几乎总是,最终是一种关系。 @ManyToOne(
我一直在使用NHibernate,使用Fluent NHibernate进行映射。我解决了很多问题,并开始认为自己在nhibernate中经验丰富。 但是,此错误非常奇怪。 这是我的模型: p
我正在开发一个 Typescript Sequelize 项目,其中我的 /models/index.ts 文件具有以下“导入此目录中的所有模型”功能: var basename = path.bas
我是一名优秀的程序员,十分优秀!