2020-07-29 08:09:45 -04:00
---
stage: Create
group: Editor
info: "To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#designated-technical-writers"
type: index, reference, howto
---
2017-04-07 07:51:35 -04:00
# Search through GitLab
## Issues and merge requests
2018-10-29 04:30:10 -04:00
To search through issues and merge requests in multiple projects, you can use the **Issues** or **Merge Requests** links
in the top-right part of your screen.
2017-04-07 07:51:35 -04:00
2018-10-29 04:30:10 -04:00
Both of them work in the same way, therefore, the following notes are valid for both.
2017-04-07 07:51:35 -04:00
The number displayed on their right represents the number of issues and merge requests assigned to you.
2018-10-29 04:30:10 -04:00
![issues and MRs dashboard links ](img/dashboard_links.png )
2017-04-07 07:51:35 -04:00
When you click **Issues** , you'll see the opened issues assigned to you straight away:
![Issues assigned to you ](img/issues_assigned_to_you.png )
2018-10-29 04:30:10 -04:00
You can search through **Open** , **Closed** , or **All** issues.
2017-04-07 07:51:35 -04:00
2020-01-07 22:08:05 -05:00
You can also filter the results using the search and filter field, as described below in
[Filtering issue and merge request lists ](#filtering-issue-and-merge-request-lists ).
2017-04-07 07:51:35 -04:00
### Issues and MRs assigned to you or created by you
2018-10-29 04:30:10 -04:00
You'll also find shortcuts to issues and merge requests created by you or assigned to you
2017-04-07 07:51:35 -04:00
on the search field on the top-right of your screen:
2020-10-15 20:08:56 -04:00
![shortcut to your issues and merge requests ](img/issues_mrs_shortcut.png )
2017-04-07 07:51:35 -04:00
2020-01-07 22:08:05 -05:00
### Filtering issue and merge request lists
2017-04-07 07:51:35 -04:00
2020-01-07 22:08:05 -05:00
Follow these steps to filter the **Issues** and **Merge Requests** list pages within projects and
groups:
2017-04-07 07:51:35 -04:00
2020-01-07 22:08:05 -05:00
1. Click in the field **Search or filter results...** .
2020-01-31 01:08:59 -05:00
1. In the dropdown menu that appears, select the attribute you wish to filter by:
- Author
- Assignee
- [Milestone ](../project/milestones/index.md )
- Release
- [Label ](../project/labels.md )
- My-reaction
- Confidential
2020-04-30 14:09:38 -04:00
- Epic ([introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/195704) in GitLab 12.9),
2020-09-07 11:09:04 -04:00
including [child epic ](../group/epics/index.md#multi-level-child-epics )
2020-04-30 14:09:38 -04:00
([introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/9029) in
[GitLab Ultimate ](https://about.gitlab.com/pricing/ ) 13.0)
2020-01-31 01:08:59 -05:00
- Search for this text
2020-01-07 22:08:05 -05:00
1. Select or type the operator to use for filtering the attribute. The following operators are
available:
- `=` : Is
2020-05-21 23:08:28 -04:00
- `!=` : Is not ([Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/18059) in GitLab 12.7)
2020-05-29 14:08:26 -04:00
1. Enter the text to [filter the attribute by ](#filters-autocomplete ).
2020-01-07 22:08:05 -05:00
1. Repeat this process to filter by multiple attributes. Multiple attributes are joined by a logical
`AND` .
2017-04-07 07:51:35 -04:00
2020-01-07 22:08:05 -05:00
For example, filtering by Author `=` Jane and Milestone `!=` 12.6 filters for the issues where Jane
is the author and the milestone is not 12.6.
![filter issues in a project ](img/issue_search_filter_v12_7.png )
2017-04-07 07:51:35 -04:00
2018-10-25 05:55:17 -04:00
### Filtering by **None** / **Any**
Some filter fields like milestone and assignee, allow you to filter by **None** or **Any** .
![filter by none any ](img/issues_filter_none_any.png )
Selecting **None** returns results that have an empty value for that field. E.g.: no milestone, no assignee.
Selecting **Any** does the opposite. It returns results that have a non-empty value for that field.
2017-09-02 23:58:56 -04:00
### Searching for specific terms
2017-09-05 09:22:16 -04:00
You can filter issues and merge requests by specific terms included in titles or descriptions.
2017-09-02 23:58:56 -04:00
2018-11-13 01:07:16 -05:00
- Syntax
2019-07-21 21:49:37 -04:00
- Searches look for all the words in a query, in any order. E.g.: searching
issues for `display bug` will return all issues matching both those words, in any order.
- To find the exact term, use double quotes: `"display bug"`
2018-11-13 01:07:16 -05:00
- Limitation
2019-07-21 21:49:37 -04:00
- For performance reasons, terms shorter than 3 chars are ignored. E.g.: searching
issues for `included in titles` is same as `included titles`
2019-12-26 16:07:49 -05:00
- Search is limited to 4096 characters and 64 terms per query.
2017-09-05 09:22:16 -04:00
![filter issues by specific terms ](img/issue_search_by_term.png )
2017-09-02 23:58:56 -04:00
2020-04-15 23:09:10 -04:00
### Filtering by ID
2020-05-21 23:08:28 -04:00
> [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/issues/39908) in GitLab 12.1.
2020-04-15 23:09:10 -04:00
You can filter the **Issues** list to individual instances by their ID. For example, enter filter `#10` to return only issue 10. The same applies to the **Merge Requests** list. Enter filter `#30` to return only merge request 30.
![filter issues by specific id ](img/issue_search_by_id.png )
2020-01-28 22:08:38 -05:00
### Filtering merge requests by approvers **(STARTER)**
2020-02-06 10:09:11 -05:00
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/9468) in [GitLab Starter](https://about.gitlab.com/pricing/) 11.9.
2020-01-28 22:08:38 -05:00
To filter merge requests by an individual approver, you can type (or select from
2020-05-13 17:08:55 -04:00
the dropdown) **Approver** and select the user.
2020-01-28 22:08:38 -05:00
![Filter MRs by an approver ](img/filter_approver_merge_requests.png )
2020-05-13 17:08:55 -04:00
### Filtering merge requests by "approved by" **(STARTER)**
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/30335) in [GitLab Starter](https://about.gitlab.com/pricing/) 13.0.
To filter merge requests already approved by a specific individual, you can type (or select from
the dropdown) **Approved-By** and select the user.
![Filter MRs by approved by ](img/filter_approved_by_merge_requests_v13_0.png )
2020-05-29 14:08:26 -04:00
## Filters autocomplete
GitLab provides many filters across many pages (issues, merge requests, epics,
and pipelines among others) which you can use to narrow down your search. When
using the filter functionality, you can start typing characters to bring up
relevant users or other attributes.
For performance optimization, there is a requirement of a minimum of three
characters to begin your search. For example, if you want to search for
issues that have the assignee "Simone Presley", you'll need to type at
least "Sim" before autocomplete gives any relevant results.
2017-05-19 11:37:04 -04:00
## Search history
2017-04-12 15:56:54 -04:00
2017-04-13 11:27:28 -04:00
You can view recent searches by clicking on the little arrow-clock icon, which is to the left of the search input. Click the search entry to run that search again. This feature is available for issues and merge requests. Searches are stored locally in your browser.
2017-04-12 15:56:54 -04:00
![search history ](img/search_history.gif )
2017-05-19 11:37:04 -04:00
## Removing search filters
2020-04-15 14:09:36 -04:00
Individual filters can be removed by clicking on the filter's (x) button or backspacing. The entire search filter can be cleared by clicking on the search box's (x) button or via < kbd > ⌘< / kbd > (Mac) + < kbd > ⌫< / kbd > .
To delete filter tokens one at a time, the < kbd > ⌥< / kbd > (Mac) / < kbd > Ctrl< / kbd > + < kbd > ⌫< / kbd > keyboard combination can be used.
2017-05-19 11:37:04 -04:00
2019-05-05 09:07:20 -04:00
## Filtering with multiple filters of the same type
Some filters can be added multiple times. These include but are not limited to assignees and labels. When you filter with these multiple filters of the same type, the AND logic is applied. For example, if you were filtering `assignee:@sam assignee:@sarah` , your results will only include entries whereby the assignees are assigned to both Sam and Sarah are returned.
![multiple assignees filtering ](img/multiple_assignees.png )
2019-07-04 11:45:54 -04:00
## To-Do List
2017-04-07 07:51:35 -04:00
2019-10-28 02:06:30 -04:00
Your [To-Do List ](../todos.md#gitlab-to-do-list ) can be searched by "to do" and "done".
You can [filter ](../todos.md#filtering-your-to-do-list ) them per project,
2017-04-07 07:51:35 -04:00
author, type, and action. Also, you can sort them by
2019-03-05 07:55:30 -05:00
[**Label priority** ](../../user/project/labels.md#label-priority ),
2020-02-26 19:09:19 -05:00
**Last created**, and **Oldest created** .
2017-04-07 07:51:35 -04:00
## Projects
You can search through your projects from the left menu, by clicking the menu bar, then **Projects** .
On the field **Filter by name** , type the project or group name you want to find, and GitLab
will filter them for you as you type.
2020-06-07 11:08:36 -04:00
You can also look for the projects you [starred ](../project/index.md#star-a-project ) (**Starred projects**), and **Explore** all
2018-04-27 04:50:05 -04:00
public and internal projects available in GitLab.com, from which you can filter by visibility,
2020-06-07 11:08:36 -04:00
through **Trending** , best rated with **Most stars** , or **All** of them.
2017-04-07 07:51:35 -04:00
You can also sort them by **Name** , **Last created** , **Oldest created** , **Last updated** ,
**Oldest updated**, **Owner** , and choose to hide or show **archived projects** :
![sort projects ](img/sort_projects.png )
## Groups
Similarly to [projects search ](#projects ), you can search through your groups from
the left menu, by clicking the menu bar, then **Groups** .
On the field **Filter by name** , type the group name you want to find, and GitLab
will filter them for you as you type.
You can also **Explore** all public and internal groups available in GitLab.com,
and sort them by **Last created** , **Oldest created** , **Last updated** , or **Oldest updated** .
## Issue Boards
From an [Issue Board ](../../user/project/issue_board.md ), you can filter issues by **Author** , **Assignee** , **Milestone** , and **Labels** .
You can also filter them by name (issue title), from the field **Filter by name** , which is loaded as you type.
When you want to search for issues to add to lists present in your Issue Board, click
the button **Add issues** on the top-right of your screen, opening a modal window from which
you'll be able to, besides filtering them by **Name** , **Author** , **Assignee** , **Milestone** ,
and **Labels** , select multiple issues to add to a list of your choice:
![search and select issues to add to board ](img/search_issues_board.png )
2019-05-05 09:07:20 -04:00
2020-10-01 08:10:14 -04:00
## Shortcut
You'll find a shortcut on the search field on the top-right of the project's dashboard to
quickly access issues and merge requests created or assigned to you within that project:
![search per project - shortcut ](img/project_search.png )
### Autocomplete suggestions
You can also type in this search bar to see autocomplete suggestions for:
- Projects and groups
- Various help pages (try and type **API help** )
- Project feature pages (try and type **milestones** )
- Various settings pages (try and type **user settings** )
- Recently viewed issues (try and type some word from the title of a recently viewed issue)
2020-10-05 11:08:56 -04:00
- Recently viewed merge requests (try and type some word from the title of a recently viewed merge request)
- Recently viewed epics (try and type some word from the title of a recently viewed epic)
2020-10-01 08:10:14 -04:00
## Basic search
The Basic search in GitLab is a global search service that allows you to search
across the entire GitLab instance, within a group, or a single project. Basic search is
backed by the database and allows searching in:
- Projects
- Issues
- Merge requests
- Milestones
- Users
2020-10-06 23:08:19 -04:00
- Epics (Group only)
2020-10-01 08:10:14 -04:00
- Code (Project only)
- Comments (Project only)
- Commits (Project only)
- Wiki (Project only)
2020-10-08 05:08:40 -04:00
To start a search, type into the search bar on the top-right of the screen. You can always search
2020-10-01 08:10:14 -04:00
in all GitLab and may also see the options to search within a group or project if you are in the
group or project dashboard.
![basic search ](img/basic_search.png )
Once the results are returned, you can modify the search, select a different type of data to
search, or choose a specific group or project.
![basic_search_results ](img/basic_search_results.png )
2020-10-08 05:08:40 -04:00
2020-10-01 08:10:14 -04:00
### Code search
To search through code or other documents in a single project, you can use
the search field on the top-right of your screen while the project page is open.
![code search dropdown ](img/project_search_dropdown.png )
![code search results ](img/project_code_search.png )
2020-10-21 23:08:25 -04:00
### SHA search
You can quickly access a commit from within the project dashboard by entering the SHA
into the search field on the top right of the screen. If a single result is found, you will be
redirected to the commit result and given the option to return to the search results page.
![project sha search redirect ](img/project_search_sha_redirect.png )
2020-08-27 02:10:37 -04:00
## Advanced Search **(STARTER)**
2019-05-05 09:07:20 -04:00
Leverage Elasticsearch for faster, more advanced code search across your entire
GitLab instance.
2020-08-27 02:10:37 -04:00
[Learn how to use the Advanced Search. ](advanced_global_search.md )
2019-05-05 09:07:20 -04:00
2020-08-28 14:10:51 -04:00
## Advanced Search Syntax **(STARTER)**
2019-05-05 09:07:20 -04:00
Use advanced queries for more targeted search results.
2020-08-28 14:10:51 -04:00
[Learn how to use the Advanced Search Syntax. ](advanced_search_syntax.md )