File: /home/accemeff/vendor/craftcms/cms/docs/dev/element-queries/tag-queries.md
# Tag Queries
You can fetch tags in your templates or PHP code using **tag queries**.
::: code
```twig
{# Create a new tag query #}
{% set myTagQuery = craft.tags() %}
```
```php
// Create a new tag query
$myTagQuery = \craft\elements\Tag::find();
```
:::
Once you’ve created a tag query, you can set [parameters](#parameters) on it to narrow down the results, and then [execute it](README.md#executing-element-queries) by calling `.all()`. An array of [Tag](api:craft\elements\Tag) objects will be returned.
::: tip
See [Introduction to Element Queries](README.md) to learn about how element queries work.
:::
## Example
We can display a list of the tags in a “Blog Tags” tag group by doing the following:
1. Create a tag query with `craft.tags()`.
2. Set the [group](#group) parameter on it.
3. Fetch the tags with `.all()`.
4. Loop through the tags using a [for](https://twig.symfony.com/doc/2.x/tags/for.html) tag to create the list HTML.
```twig
{# Create a tag query with the 'group' parameter #}
{% set myTagQuery = craft.tags()
.group('blogTags') %}
{# Fetch the tags #}
{% set tags = myTagQuery.all() %}
{# Display the tag list #}
<ul>
{% for tag in tags %}
<li><a href="{{ url('blog/tags/'~tag.id) }}">{{ tag.title }}</a></li>
{% endfor %}
</ul>
```
## Parameters
Tag queries support the following parameters:
<!-- BEGIN PARAMS -->
### `anyStatus`
Clears out the [status()](https://docs.craftcms.com/api/v3/craft-elements-db-elementquery.html#method-status) and [enabledForSite()](https://docs.craftcms.com/api/v3/craft-elements-db-elementquery.html#method-enabledforsite) parameters.
::: code
```twig
{# Fetch all tags, regardless of status #}
{% set tags = craft.tags()
.anyStatus()
.all() %}
```
```php
// Fetch all tags, regardless of status
$tags = \craft\elements\Tag::find()
->anyStatus()
->all();
```
:::
### `asArray`
Causes the query to return matching tags as arrays of data, rather than [Tag](api:craft\elements\Tag) objects.
::: code
```twig
{# Fetch tags as arrays #}
{% set tags = craft.tags()
.asArray()
.all() %}
```
```php
// Fetch tags as arrays
$tags = \craft\elements\Tag::find()
->asArray()
->all();
```
:::
### `dateCreated`
Narrows the query results based on the tags’ creation dates.
Possible values include:
| Value | Fetches tags…
| - | -
| `'>= 2018-04-01'` | that were created on or after 2018-04-01.
| `'< 2018-05-01'` | that were created before 2018-05-01
| `['and', '>= 2018-04-04', '< 2018-05-01']` | that were created between 2018-04-01 and 2018-05-01.
::: code
```twig
{# Fetch tags created last month #}
{% set start = date('first day of last month')|atom %}
{% set end = date('first day of this month')|atom %}
{% set tags = craft.tags()
.dateCreated(['and', ">= #{start}", "< #{end}"])
.all() %}
```
```php
// Fetch tags created last month
$start = new \DateTime('first day of next month')->format(\DateTime::ATOM);
$end = new \DateTime('first day of this month')->format(\DateTime::ATOM);
$tags = \craft\elements\Tag::find()
->dateCreated(['and', ">= {$start}", "< {$end}"])
->all();
```
:::
### `dateUpdated`
Narrows the query results based on the tags’ last-updated dates.
Possible values include:
| Value | Fetches tags…
| - | -
| `'>= 2018-04-01'` | that were updated on or after 2018-04-01.
| `'< 2018-05-01'` | that were updated before 2018-05-01
| `['and', '>= 2018-04-04', '< 2018-05-01']` | that were updated between 2018-04-01 and 2018-05-01.
::: code
```twig
{# Fetch tags updated in the last week #}
{% set lastWeek = date('1 week ago')|atom %}
{% set tags = craft.tags()
.dateUpdated(">= #{lastWeek}")
.all() %}
```
```php
// Fetch tags updated in the last week
$lastWeek = new \DateTime('1 week ago')->format(\DateTime::ATOM);
$tags = \craft\elements\Tag::find()
->dateUpdated(">= {$lastWeek}")
->all();
```
:::
### `fixedOrder`
Causes the query results to be returned in the order specified by [id](#id).
::: code
```twig
{# Fetch tags in a specific order #}
{% set tags = craft.tags()
.id([1, 2, 3, 4, 5])
.fixedOrder()
.all() %}
```
```php
// Fetch tags in a specific order
$tags = \craft\elements\Tag::find()
->id([1, 2, 3, 4, 5])
->fixedOrder()
->all();
```
:::
### `group`
Narrows the query results based on the tag groups the tags belong to.
Possible values include:
| Value | Fetches tags…
| - | -
| `'foo'` | in a group with a handle of `foo`.
| `'not foo'` | not in a group with a handle of `foo`.
| `['foo', 'bar']` | in a group with a handle of `foo` or `bar`.
| `['not', 'foo', 'bar']` | not in a group with a handle of `foo` or `bar`.
| a [TagGroup](api:craft\models\TagGroup) object | in a group represented by the object.
::: code
```twig
{# Fetch tags in the Foo group #}
{% set tags = craft.tags()
.group('foo')
.all() %}
```
```php
// Fetch tags in the Foo group
$tags = \craft\elements\Tag::find()
->group('foo')
->all();
```
:::
### `groupId`
Narrows the query results based on the tag groups the tags belong to, per the groups’ IDs.
Possible values include:
| Value | Fetches tags…
| - | -
| `1` | in a group with an ID of 1.
| `'not 1'` | not in a group with an ID of 1.
| `[1, 2]` | in a group with an ID of 1 or 2.
| `['not', 1, 2]` | not in a group with an ID of 1 or 2.
::: code
```twig
{# Fetch tags in the group with an ID of 1 #}
{% set tags = craft.tags()
.groupId(1)
.all() %}
```
```php
// Fetch tags in the group with an ID of 1
$tags = \craft\elements\Tag::find()
->groupId(1)
->all();
```
:::
### `id`
Narrows the query results based on the tags’ IDs.
Possible values include:
| Value | Fetches tags…
| - | -
| `1` | with an ID of 1.
| `'not 1'` | not with an ID of 1.
| `[1, 2]` | with an ID of 1 or 2.
| `['not', 1, 2]` | not with an ID of 1 or 2.
::: code
```twig
{# Fetch the tag by its ID #}
{% set tag = craft.tags()
.id(1)
.one() %}
```
```php
// Fetch the tag by its ID
$tag = \craft\elements\Tag::find()
->id(1)
->one();
```
:::
::: tip
This can be combined with [fixedOrder](#fixedorder) if you want the results to be returned in a specific order.
:::
### `inReverse`
Causes the query results to be returned in reverse order.
::: code
```twig
{# Fetch tags in reverse #}
{% set tags = craft.tags()
.inReverse()
.all() %}
```
```php
// Fetch tags in reverse
$tags = \craft\elements\Tag::find()
->inReverse()
->all();
```
:::
### `limit`
Determines the number of tags that should be returned.
::: code
```twig
{# Fetch up to 10 tags #}
{% set tags = craft.tags()
.limit(10)
.all() %}
```
```php
// Fetch up to 10 tags
$tags = \craft\elements\Tag::find()
->limit(10)
->all();
```
:::
### `offset`
Determines how many tags should be skipped in the results.
::: code
```twig
{# Fetch all tags except for the first 3 #}
{% set tags = craft.tags()
.offset(3)
.all() %}
```
```php
// Fetch all tags except for the first 3
$tags = \craft\elements\Tag::find()
->offset(3)
->all();
```
:::
### `orderBy`
Determines the order that the tags should be returned in.
::: code
```twig
{# Fetch all tags in order of date created #}
{% set tags = craft.tags()
.orderBy('elements.dateCreated asc')
.all() %}
```
```php
// Fetch all tags in order of date created
$tags = \craft\elements\Tag::find()
->orderBy('elements.dateCreated asc')
->all();
```
:::
### `relatedTo`
Narrows the query results to only tags that are related to certain other elements.
See [Relations](https://docs.craftcms.com/v3/relations.html) for a full explanation of how to work with this parameter.
::: code
```twig
{# Fetch all tags that are related to myCategory #}
{% set tags = craft.tags()
.relatedTo(myCategory)
.all() %}
```
```php
// Fetch all tags that are related to $myCategory
$tags = \craft\elements\Tag::find()
->relatedTo($myCategory)
->all();
```
:::
### `search`
Narrows the query results to only tags that match a search query.
See [Searching](https://docs.craftcms.com/v3/searching.html) for a full explanation of how to work with this parameter.
::: code
```twig
{# Get the search query from the 'q' query string param #}
{% set searchQuery = craft.request.getQueryParam('q') %}
{# Fetch all tags that match the search query #}
{% set tags = craft.tags()
.search(searchQuery)
.all() %}
```
```php
// Get the search query from the 'q' query string param
$searchQuery = \Craft::$app->request->getQueryParam('q');
// Fetch all tags that match the search query
$tags = \craft\elements\Tag::find()
->search($searchQuery)
->all();
```
:::
### `site`
Determines which site the tags should be queried in.
The current site will be used by default.
Possible values include:
| Value | Fetches tags…
| - | -
| `'foo'` | from the site with a handle of `foo`.
| a `\craft\elements\db\Site` object | from the site represented by the object.
::: code
```twig
{# Fetch tags from the Foo site #}
{% set tags = craft.tags()
.site('foo')
.all() %}
```
```php
// Fetch tags from the Foo site
$tags = \craft\elements\Tag::find()
->site('foo')
->all();
```
:::
### `siteId`
Determines which site the tags should be queried in, per the site’s ID.
The current site will be used by default.
::: code
```twig
{# Fetch tags from the site with an ID of 1 #}
{% set tags = craft.tags()
.siteId(1)
.all() %}
```
```php
// Fetch tags from the site with an ID of 1
$tags = \craft\elements\Tag::find()
->siteId(1)
->all();
```
:::
### `title`
Narrows the query results based on the tags’ titles.
Possible values include:
| Value | Fetches tags…
| - | -
| `'Foo'` | with a title of `Foo`.
| `'Foo*'` | with a title that begins with `Foo`.
| `'*Foo'` | with a title that ends with `Foo`.
| `'*Foo*'` | with a title that contains `Foo`.
| `'not *Foo*'` | with a title that doesn’t contain `Foo`.
| `['*Foo*', '*Bar*'` | with a title that contains `Foo` or `Bar`.
| `['not', '*Foo*', '*Bar*']` | with a title that doesn’t contain `Foo` or `Bar`.
::: code
```twig
{# Fetch tags with a title that contains "Foo" #}
{% set tags = craft.tags()
.title('*Foo*')
.all() %}
```
```php
// Fetch tags with a title that contains "Foo"
$tags = \craft\elements\Tag::find()
->title('*Foo*')
->all();
```
:::
### `trashed`
Narrows the query results to only tags that have been soft-deleted.
::: code
```twig
{# Fetch trashed tags #}
{% set tags = {twig-function}
.trashed()
.all() %}
```
```php
// Fetch trashed tags
$tags = \craft\elements\Tag::find()
->trashed()
->all();
```
:::
### `uid`
Narrows the query results based on the tags’ UIDs.
::: code
```twig
{# Fetch the tag by its UID #}
{% set tag = craft.tags()
.uid('xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx')
.one() %}
```
```php
// Fetch the tag by its UID
$tag = \craft\elements\Tag::find()
->uid('xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx')
->one();
```
:::
### `uri`
Narrows the query results based on the tags’ URIs.
Possible values include:
| Value | Fetches tags…
| - | -
| `'foo'` | with a URI of `foo`.
| `'foo*'` | with a URI that begins with `foo`.
| `'*foo'` | with a URI that ends with `foo`.
| `'*foo*'` | with a URI that contains `foo`.
| `'not *foo*'` | with a URI that doesn’t contain `foo`.
| `['*foo*', '*bar*'` | with a URI that contains `foo` or `bar`.
| `['not', '*foo*', '*bar*']` | with a URI that doesn’t contain `foo` or `bar`.
::: code
```twig
{# Get the requested URI #}
{% set requestedUri = craft.app.request.getPathInfo() %}
{# Fetch the tag with that URI #}
{% set tag = craft.tags()
.uri(requestedUri|literal)
.one() %}
```
```php
// Get the requested URI
$requestedUri = \Craft::$app->request->getPathInfo();
// Fetch the tag with that URI
$tag = \craft\elements\Tag::find()
->uri(\craft\helpers\Db::escapeParam($requestedUri))
->one();
```
:::
### `with`
Causes the query to return matching tags eager-loaded with related elements.
See [Eager-Loading Elements](https://docs.craftcms.com/v3/dev/eager-loading-elements.html) for a full explanation of how to work with this parameter.
::: code
```twig
{# Fetch tags eager-loaded with the "Related" field’s relations #}
{% set tags = craft.tags()
.with(['related'])
.all() %}
```
```php
// Fetch tags eager-loaded with the "Related" field’s relations
$tags = \craft\elements\Tag::find()
->with(['related'])
->all();
```
:::
<!-- END PARAMS -->