Entity Service API
The content of this page has not been updated to Strapi v5 yet.
Before diving deeper into the Entity Service API documentation, it is recommended that you read the following introductions:
The Strapi backend provides an Entity Service API, built on top of the Query Engine API. The Entity Service is the layer that handles Strapi's complex data structures like components and dynamic zones, and uses the Query Engine API under the hood to execute database queries.
Strapi v4 offers several layers to interact with the backend and build your queries:
- The Entity Service API is the recommended API to interact with your application's database. The Entity Service is the layer that handles Strapi's complex data structures like components and dynamic zones, which the lower-level layers are not aware of.
- The Query Engine API interacts with the database layer at a lower level and is used under the hood to execute database queries. It gives unrestricted internal access to the database layer, but should be used only if the Entity Service API does not cover your use case.
- If you need direct access to
knex
functions, usestrapi.db.connection
.
While services can use the Entity Service API, services and the Entity Service API are not directly related. You can find more information about the core elements of the Strapi back end in the back-end customization documentation.
Basic usage
The Entity Service is available through strapi.entityService
:
const entry = await strapi.entityService.findOne('api::article.article', 1, {
populate: { someRelation: true },
});
Available operations
The Entity Service API allows the following operations on entities:
📄️ CRUD operations
Create, read, update, and delete entities with the Entity Service API.
📄️ Filters
Get exactly what you need by filtering entities with your Entity Service API queries.
📄️ Populate
Get additional data with your Entity Service API queries by populating relations.
📄️ Order & Pagination
Sort and paginate the results of your Entity Service API queries.
📄️ Components/Dynamic Zones
Create and update components and dynamic zones with your Entity Service API queries.