mirror of
https://github.com/cwinfo/powerdns-admin.git
synced 2024-11-09 15:10:27 +00:00
Dashboard history query performance related change to nested subquery (allowed domains for user).
This commit is contained in:
parent
dc69f00094
commit
ec687b13a5
@ -165,30 +165,24 @@ def dashboard():
|
|||||||
history_number = History.query.count()
|
history_number = History.query.count()
|
||||||
history = History.query.order_by(History.created_on.desc()).limit(4).all()
|
history = History.query.order_by(History.created_on.desc()).limit(4).all()
|
||||||
elif Setting().get('allow_user_view_history'):
|
elif Setting().get('allow_user_view_history'):
|
||||||
history = db.session.query(History) \
|
allowed_domain_id_subquery = db.session.query(Domain.id) \
|
||||||
.with_hint(History, "FORCE INDEX (ix_history_created_on)", 'mysql') \
|
|
||||||
.join(Domain, History.domain_id == Domain.id) \
|
|
||||||
.outerjoin(DomainUser, Domain.id == DomainUser.domain_id) \
|
.outerjoin(DomainUser, Domain.id == DomainUser.domain_id) \
|
||||||
.outerjoin(Account, Domain.account_id == Account.id) \
|
.outerjoin(Account, Domain.account_id == Account.id) \
|
||||||
.outerjoin(AccountUser, Account.id == AccountUser.account_id) \
|
.outerjoin(AccountUser, Account.id == AccountUser.account_id) \
|
||||||
.order_by(History.created_on.desc()) \
|
.filter(db.or_(
|
||||||
.filter(
|
|
||||||
db.or_(
|
|
||||||
DomainUser.user_id == current_user.id,
|
DomainUser.user_id == current_user.id,
|
||||||
AccountUser.user_id == current_user.id
|
AccountUser.user_id == current_user.id
|
||||||
)) \
|
)) \
|
||||||
|
.subquery()
|
||||||
|
history = db.session.query(History) \
|
||||||
|
.with_hint(History, "FORCE INDEX (ix_history_created_on)", 'mysql') \
|
||||||
|
.order_by(History.created_on.desc()) \
|
||||||
|
.filter(History.domain_id.in_(allowed_domain_id_subquery)) \
|
||||||
.limit(4) \
|
.limit(4) \
|
||||||
.all()
|
.all()
|
||||||
history_number = db.session.query(History) \
|
history_number = db.session.query(History) \
|
||||||
.join(Domain, History.domain_id == Domain.id) \
|
.filter(History.domain_id.in_(allowed_domain_id_subquery)) \
|
||||||
.outerjoin(DomainUser, Domain.id == DomainUser.domain_id) \
|
.count()
|
||||||
.outerjoin(Account, Domain.account_id == Account.id) \
|
|
||||||
.outerjoin(AccountUser, Account.id == AccountUser.account_id) \
|
|
||||||
.filter(
|
|
||||||
db.or_(
|
|
||||||
DomainUser.user_id == current_user.id,
|
|
||||||
AccountUser.user_id == current_user.id
|
|
||||||
)).count()
|
|
||||||
domain_count = db.session.query(Domain) \
|
domain_count = db.session.query(Domain) \
|
||||||
.outerjoin(DomainUser, Domain.id == DomainUser.domain_id) \
|
.outerjoin(DomainUser, Domain.id == DomainUser.domain_id) \
|
||||||
.outerjoin(Account, Domain.account_id == Account.id) \
|
.outerjoin(Account, Domain.account_id == Account.id) \
|
||||||
|
Loading…
Reference in New Issue
Block a user