Resolve "Refactor Complex Query Metric - project_imports total"
What does this MR do and why?
Remove complex queries for project_imports_totals
Old Query
SELECT COUNT(projects.id) FROM \"projects\" WHERE \"projects\".\"import_type\" = ANY(VALUES ('gitlab_project' 'gitlab' 'github' 'bitbucket'))
SELECT (
SELECT COUNT(\"projects\".\"id\") FROM \"projects\" WHERE \"projects\".\"import_type\" = 'gitlab_project' AND \"projects\".\"import_type\" IS NOT NULL
)
+ (
SELECT COUNT(\"projects\".\"id\") FROM \"projects\" WHERE \"projects\".\"import_type\" = 'gitlab' AND \"projects\".\"import_type\" IS NOT NULL
) + (
SELECT COUNT(\"projects\".\"id\") FROM \"projects\" WHERE \"projects\".\"import_type\" = 'github' AND \"projects\".\"import_type\" IS NOT NULL
) + (
SELECT COUNT(\"projects\".\"id\") FROM \"projects\" WHERE \"projects\".\"import_type\" = 'bitbucket' AND \"projects\".\"import_type\" IS NOT NULL
) + (
SELECT COUNT(\"projects\".\"id\") FROM \"projects\" WHERE \"projects\".\"import_type\" = 'bitbucket_server' AND \"projects\".\"import_type\" IS NOT NULL
) + (
SELECT COUNT(\"projects\".\"id\") FROM \"projects\" WHERE \"projects\".\"import_type\" = 'gitea' AND \"projects\".\"import_type\" IS NOT NULL
) + (
SELECT COUNT(\"projects\".\"id\") FROM \"projects\" WHERE \"projects\".\"import_type\" = 'git' AND \"projects\".\"import_type\" IS NOT NULL
) + (
SELECT COUNT(\"projects\".\"id\") FROM \"projects\" WHERE \"projects\".\"import_type\" = 'manifest' AND \"projects\".\"import_type\" IS NOT NULL
) + (
SELECT COUNT(\"bulk_import_entities\".\"id\") FROM \"bulk_import_entities\" WHERE \"bulk_import_entities\".\"source_type\" = 1
)"}
New Query
=> "SELECT (
SELECT
COUNT(\"projects\".\"id\") FROM \"projects\"
WHERE \"projects\".\"import_type\" IN ('gitlab_project', 'gitlab', 'github', 'bitbucket', 'bitbucket_server', 'gitea', 'git', 'manifest')
AND \"projects\".\"import_type\" IS NOT NULL)
+ (
SELECT COUNT(\"bulk_import_entities\".\"id\") FROM \"bulk_import_entities\" WHERE \"bulk_import_entities\".\"source_type\" = 1
)"
Screenshots or screen recordings
These are strongly recommended to assist reviewers and reduce the time to merge your change.
How to set up and validate locally
Numbered steps to set up and validate the change are strongly suggested.
MR acceptance checklist
This checklist encourages us to confirm any changes have been analyzed to reduce risks in quality, performance, reliability, security, and maintainability.
-
I have evaluated the MR acceptance checklist for this MR.
Related to #351486 (closed)
Edited by Luis Mejia