Select Flask-SQLAlchemy 多对多
Select many to many with Flask-SQLAlchemy
我正在尝试 SELECT 使用 Flask-SQLAlchemy 从数据库中提取一些数据。但是,我正在努力获取正确的数据并加入多对多。
我的模型是这样的。
class User(UserMixin, db.Model):
id = db.Column(db.Integer, primary_key=True)
user_firstName = db.Column(db.String(64))
...
role_id = db.Column(db.Integer, db.ForeignKey('role.role_id'))
class Role(db.Model):
role_id = db.Column(db.Integer, primary_key=True)
role_name = db.Column(db.String(64), unique=True)
users = db.relationship('User', backref='role')
然后 table 我想得到多对多
note using backref
class Class(db.Model):
class_id = db.Column(db.Integer, primary_key=True)
class_name = db.Column(db.String(128), unique=True)
mm_children = db.relationship('User', secondary=student_identifier, backref=db.backref('classes'))
这里是 table,其中包含多对多信息(用户和 class 之间的 link)
student_identifier = db.Table('student_identifier',
db.Column('class_id', db.Integer, db.ForeignKey('class.class_id')),
db.Column('id', db.Integer, db.ForeignKey('user.id'))
)
假设我的数据库中有这个
User
id user_firstName role_id
1 'John' 3
2 'Jane' 3
3 'Jack' 1
4 'Jimmy' 3
5 'Jana' 2
Role
role_id role_name
1 'Admin'
2 'Teacher'
3 Student'
Class
class_id class_name
1 'A'
2 'B'
3 'C'
student_identfier
class_id id
1 1
1 2
2 2
3 1
1 4
student_identfier
class_id id
1 1
1 2
2 2
3 1
1 4
那么如果你想循环所有具有 class id 1 和 2 的人。并获取他们的名字
id class_name role_name
1 'A' 'Student'
2 'A' 'Student'
2 'B' 'Student'
编辑
我设法得到 classes,但没有 in 子句。
db.session.query(
User.user_fistName,
Role.role_name,
Class.class_name
).join(Role).filter_by(role_name='Student').filter(User.classes)
如果您的模型和关系有效,您应该可以这样做:
users = session.query(User).all()
for user in users:
users_classes = ','.join([c.class_name for c in user.classes])
print("{0} is {1} in {2}".format(user.user_firstName,
user.role.role_name,
users_classes))
希望对您有所帮助。
我正在尝试 SELECT 使用 Flask-SQLAlchemy 从数据库中提取一些数据。但是,我正在努力获取正确的数据并加入多对多。
我的模型是这样的。
class User(UserMixin, db.Model):
id = db.Column(db.Integer, primary_key=True)
user_firstName = db.Column(db.String(64))
...
role_id = db.Column(db.Integer, db.ForeignKey('role.role_id'))
class Role(db.Model):
role_id = db.Column(db.Integer, primary_key=True)
role_name = db.Column(db.String(64), unique=True)
users = db.relationship('User', backref='role')
然后 table 我想得到多对多
note using backref
class Class(db.Model):
class_id = db.Column(db.Integer, primary_key=True)
class_name = db.Column(db.String(128), unique=True)
mm_children = db.relationship('User', secondary=student_identifier, backref=db.backref('classes'))
这里是 table,其中包含多对多信息(用户和 class 之间的 link)
student_identifier = db.Table('student_identifier',
db.Column('class_id', db.Integer, db.ForeignKey('class.class_id')),
db.Column('id', db.Integer, db.ForeignKey('user.id'))
)
假设我的数据库中有这个
User
id user_firstName role_id
1 'John' 3
2 'Jane' 3
3 'Jack' 1
4 'Jimmy' 3
5 'Jana' 2
Role
role_id role_name
1 'Admin'
2 'Teacher'
3 Student'
Class
class_id class_name
1 'A'
2 'B'
3 'C'
student_identfier
class_id id
1 1
1 2
2 2
3 1
1 4
student_identfier
class_id id
1 1
1 2
2 2
3 1
1 4
那么如果你想循环所有具有 class id 1 和 2 的人。并获取他们的名字
id class_name role_name
1 'A' 'Student'
2 'A' 'Student'
2 'B' 'Student'
编辑
我设法得到 classes,但没有 in 子句。
db.session.query(
User.user_fistName,
Role.role_name,
Class.class_name
).join(Role).filter_by(role_name='Student').filter(User.classes)
如果您的模型和关系有效,您应该可以这样做:
users = session.query(User).all()
for user in users:
users_classes = ','.join([c.class_name for c in user.classes])
print("{0} is {1} in {2}".format(user.user_firstName,
user.role.role_name,
users_classes))
希望对您有所帮助。