mirror of
https://github.com/open-webui/open-webui.git
synced 2026-05-06 10:58:17 -05:00
[PR #21155] [CLOSED] feat: get all group query optimization #25951
Reference in New Issue
Block a user
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
📋 Pull Request Information
Original PR: https://github.com/open-webui/open-webui/pull/21155
Author: @ylwy0178-ctrl
Created: 2/4/2026
Status: ❌ Closed
Base:
dev← Head:bugfix/get_all_group_query_optimization📝 Commits (10+)
fe6783cMerge pull request #19030 from open-webui/devfc05e0aMerge pull request #19405 from open-webui/deve3faec6Merge pull request #19416 from open-webui/dev9899293Merge pull request #19448 from open-webui/dev140605eMerge pull request #19462 from open-webui/dev6f1486fMerge pull request #19466 from open-webui/devd95f533Merge pull request #19729 from open-webui/deva7271530.6.43 (#20093)6adde20Merge pull request #20394 from open-webui/devf9b0534Merge pull request #20522 from open-webui/dev📊 Changes
1 file changed (+30 additions, -17 deletions)
View changed files
📝
backend/open_webui/models/groups.py(+30 -17)📄 Description
Pull Request Checklist
Pre-Submission Checklist
Before submitting your pull request, please confirm the following:
Target Branch
devbranchdevwill lead to immediate closureDescription
Changelog
Documentation
Dependencies
Testing
Agentic AI Code
Code Review
Pull Request Title Prefix
Prefix your pull request title with one of the following:
BREAKING CHANGE:Compatibility-impacting changesbuild:Build system or dependency changesci:CI workflow updateschore:Cleanup or non-functional changesdocs:Documentation updatesfeat:New features or enhancementsfix:Bug fixesi18n:Internationalization or localizationperf:Performance improvementsrefactor:Code restructuringstyle:Formatting or stylistic changestest:Test additions or correctionsWIP:Work in progressChangelog Entry
Description
Slightly improves performance for
/api/modelsby ensuring each function is loaded only once from the database.Changes Made
get_groups()MethodBefore
get_group_member_count_by_id()for each groupAfter
LEFT OUTER JOINonGroupMemberfunc.count()aggregationsearch_groups()MethodBefore
After
offset/limit) preservedPerformance Impact
N + 1→1O(N+1)→O(1)Contributor License Agreement (CLA)
By submitting this pull request, I confirm that I have read and fully agree to the Contributor License Agreement (CLA), and I am providing my contributions under its terms.
🔄 This issue represents a GitHub Pull Request. It cannot be merged through Gitea due to API limitations.