mirror of
https://github.com/strapi/strapi.git
synced 2025-10-24 06:23:40 +00:00
290 lines
5.5 KiB
Markdown
290 lines
5.5 KiB
Markdown
# Queries
|
|
|
|
Strapi provides a utility function `strapi.query` to make database queries.
|
|
|
|
You can just call `strapi.query(modelName, pluginName)` to access the query API for any model.
|
|
|
|
These queries handle for you specific Strapi features like `groups`, `filters` and `search`.
|
|
|
|
## API Reference
|
|
|
|
### `findOne`
|
|
|
|
This method returns the first entry matching some basic params.
|
|
You can also pass a populate option to specify which relations you want to be populated.
|
|
|
|
#### Examples
|
|
|
|
**Find one by id**:
|
|
|
|
```js
|
|
strapi.query('post').findOne({ id: 1 });
|
|
```
|
|
|
|
**Find one by title**:
|
|
|
|
```js
|
|
strapi.query('post').findOne({ title: 'my title' });
|
|
```
|
|
|
|
**Find one by title and creation_date**:
|
|
|
|
```js
|
|
strapi
|
|
.query('post')
|
|
.findOne({ title: 'my title', date: '2019-01-01T00:00:00Z' });
|
|
```
|
|
|
|
**Find one by id and populate a relation**
|
|
|
|
```js
|
|
strapi.query('post').findOne({ id: 1 }, ['tag', 'tag.picture']);
|
|
```
|
|
|
|
### `find`
|
|
|
|
This method returns a list of entries matching Strapi filters.
|
|
You can also pass a populate option to specify which relations you want to be populated.
|
|
|
|
#### Examples
|
|
|
|
**Find by id**:
|
|
|
|
```js
|
|
strapi.query('post').find({ id: 1 });
|
|
```
|
|
|
|
**Find by in IN, with a limit**:
|
|
|
|
```js
|
|
strapi.query('post').find({ _limit: 10, id_in: [1, 2] });
|
|
```
|
|
|
|
**Find by date orderBy title**:
|
|
|
|
```js
|
|
strapi
|
|
.query('post')
|
|
.find({ date_gt: '2019-01-01T00:00:00Z', _sort: 'title:desc' });
|
|
```
|
|
|
|
**Find by id not in and populate a relation. Skip the first ten results**
|
|
|
|
```js
|
|
strapi.query('post').find({ id_nin: [1], _start: 10 }, ['tag', 'tag.picture']);
|
|
```
|
|
|
|
### `create`
|
|
|
|
Creates an entry in the database and returns the entry.
|
|
|
|
#### Example
|
|
|
|
```js
|
|
strapi.query('post').create({
|
|
title: 'Mytitle',
|
|
// this is a group field. the order is persisted in db.
|
|
seo: [
|
|
{
|
|
metadata: 'description',
|
|
value: 'My description',
|
|
},
|
|
{
|
|
metadata: 'keywords',
|
|
value: 'someKeyword,otherKeyword',
|
|
},
|
|
],
|
|
// pass the id of a media to link it to the entry
|
|
picture: 1,
|
|
// automatically creates the relations when passing the ids in the field
|
|
tags: [1, 2, 3],
|
|
});
|
|
```
|
|
|
|
### `update`
|
|
|
|
Updates an entry in the database and returns the entry.
|
|
|
|
#### Examples
|
|
|
|
**Update by id**
|
|
|
|
```js
|
|
strapi.query('post').update(
|
|
{ id: 1 },
|
|
{
|
|
title: 'Mytitle',
|
|
seo: [
|
|
{
|
|
metadata: 'description',
|
|
value: 'My description',
|
|
},
|
|
{
|
|
metadata: 'keywords',
|
|
value: 'someKeyword,otherKeyword',
|
|
},
|
|
],
|
|
// pass the id of a media to link it to the entry
|
|
picture: 1,
|
|
// automatically creates the relations when passing the ids in the field
|
|
tags: [1, 2, 3],
|
|
}
|
|
);
|
|
```
|
|
|
|
When updating an entry with its groups beware that if you send the groups without any `id` the previous groups will be deleted and replaced. You can update the groups by sending their `id` with the rest of the fields:
|
|
|
|
**Update by id and update previous groups**
|
|
|
|
```js
|
|
strapi.query('post').update(
|
|
{ id: 1 },
|
|
{
|
|
title: 'Mytitle',
|
|
seo: [
|
|
{
|
|
id: 2
|
|
metadata: 'keywords',
|
|
value: 'someKeyword,otherKeyword',
|
|
},
|
|
{
|
|
id: 1
|
|
metadata: 'description',
|
|
value: 'My description',
|
|
}
|
|
],
|
|
// pass the id of a media to link it to the entry
|
|
picture: 1,
|
|
// automatically creates the relations when passing the ids in the field
|
|
tags: [1, 2, 3],
|
|
}
|
|
);
|
|
```
|
|
|
|
**Partial update by title**
|
|
|
|
```js
|
|
strapi.query('post').update(
|
|
{ title: 'specific title' },
|
|
{
|
|
title: 'Mytitle',
|
|
}
|
|
);
|
|
```
|
|
|
|
### `delete`
|
|
|
|
Deletes and entry and return its value before deletion.
|
|
You can delete multiple entries at once with the passed params.
|
|
|
|
#### Examples
|
|
|
|
**Delete one by id**
|
|
|
|
```js
|
|
strapi.query('post').delete({ id: 1 });
|
|
```
|
|
|
|
**Delete multiple by field**
|
|
|
|
```js
|
|
strapi.query('post').delete({ lang: 'en' });
|
|
```
|
|
|
|
### `count`
|
|
|
|
Returns the count of entries matching Strapi filters.
|
|
|
|
#### Examples
|
|
|
|
**Count by lang**
|
|
|
|
```js
|
|
strapi.query('post').count({ lang: 'en' });
|
|
```
|
|
|
|
**Count by title contains**
|
|
|
|
```js
|
|
strapi.query('post').count({ title_contains: 'food' });
|
|
```
|
|
|
|
**Count by date less than**
|
|
|
|
```js
|
|
strapi.query('post').count({ date_lt: '2019-08-01T00:00:00Z' });
|
|
```
|
|
|
|
### `search`
|
|
|
|
Returns entries based on a search on all fields allowing it. (this feature will return all entries on sqlite).
|
|
|
|
#### Examples
|
|
|
|
**Search first ten starting at 20**
|
|
|
|
```js
|
|
strapi.query('post').search({ _q: 'my search query', _limit: 10, _start: 20 });
|
|
```
|
|
|
|
**Search and sort**
|
|
|
|
```js
|
|
strapi
|
|
.query('post')
|
|
.search({ _q: 'my search query', _limit: 100, _sort: 'date:desc' });
|
|
```
|
|
|
|
### `countSearch`
|
|
|
|
Returns the total count of entries based on a search. (this feature will return all entries on sqlite).
|
|
|
|
#### Example
|
|
|
|
```js
|
|
strapi.query('post').countSearch({ _q: 'my search query' });
|
|
```
|
|
|
|
## Custom Queries
|
|
|
|
When you want to customize your services or create new ones you will have to build your queries with the underlying ORM models.
|
|
|
|
To access the underlying model:
|
|
|
|
```js
|
|
strapi.query(modelName, plugin).model;
|
|
```
|
|
|
|
Then you can run any queries available on the model. You should refer to the specific ORM documentation for more details:
|
|
|
|
### Bookshelf
|
|
|
|
Documentation: [https://bookshelfjs.org/](https://bookshelfjs.org/)
|
|
|
|
**Example**
|
|
|
|
```js
|
|
const result = await strapi
|
|
.query('post')
|
|
.model.query(qb => {
|
|
qb.where('id', 1);
|
|
})
|
|
.fetch();
|
|
|
|
const fields = result.toJSON();
|
|
```
|
|
|
|
### Mongoose
|
|
|
|
Documentation: [https://mongoosejs.com/](https://mongoosejs.com/)
|
|
|
|
**Example**
|
|
|
|
```js
|
|
const result = strapi.query('post').model.find({
|
|
date: { $gte: '2019-01-01T00.00.00Z' },
|
|
});
|
|
|
|
const fields = result.toObject();
|
|
```
|