Advanced search

Tier: Premium, Ultimate Offering: GitLab.com, Self-managed, GitLab Dedicated
History
  • Moved to GitLab Premium in 13.9.

You can use advanced search for faster, more efficient search across the entire GitLab instance. Advanced search is based on Elasticsearch, a purpose-built full-text search engine you can horizontally scale to get results in up to a second in most cases.

You can find code you want to update in all projects at once to save maintenance time and promote innersourcing.

You can use advanced search in:

  • Projects
  • Issues
  • Merge requests
  • Milestones
  • Users
  • Epics
  • Code
  • Comments
  • Commits
  • Project and group wikis

Syntax

History
  • Refining user search introduced in GitLab 15.10.

Advanced search uses simple_query_string, which supports both exact and fuzzy queries.

When you search for a user, the fuzzy query is used by default. You can refine user search with simple_query_string.

Syntax Description Example
" Exact search "gem sidekiq"
~ Fuzzy search J~ Doe
| Or display | banner
+ And display +banner
- Exclude display -banner
* Partial bug error 50*
\ Escape \*md
# Issue ID #23456
! Merge request ID !23456
Syntax Description Example
filename: Filename filename:*spec.rb
path: Repository location (full or partial matches) path:spec/workers/
extension: File extension without . (exact matches only) extension:js
blob: Git object ID (exact matches only) blob:998707*

Examples

Query Description
rails -filename:gemfile.lock Returns rails in all files except the gemfile.lock file.
RSpec.describe Resolvers -*builder Returns RSpec.describe Resolvers that does not start with builder.
bug | (display +banner) Returns bug or both display and banner.
helper -extension:yml -extension:js Returns helper in all files except files with a .yml or .js extension.
helper path:lib/git Returns helper in all files with a lib/git* path (for example, spec/lib/gitlab).

Known issues

  • You can only search files smaller than 1 MB. For more information, see issue 195764. For self-managed GitLab instances, an administrator can configure the Maximum file size indexed setting.
  • You can use advanced search on the default branch of a project only. For more information, see issue 229966.
  • The search query must not contain any of the following characters:

    . , : ; / ` ' = ? $ & ^ | < > ( ) { } [ ] @
    

    For more information, see issue 325234.

  • Search results show only the first match in a file. For more information, see issue 668.