Filtering
The Entity Service API is the recommended API to interact with your application's database. Only use QueryEngine if EntityService does not cover your use case.
The Query Engine API offers the ability to filter results found with its findMany() method.
Results are filtered with the where parameter that accepts logical operators and attribute operators. Every operator should be prefixed with $.
Logical operatorsβ
$andβ
All nested conditions must be true.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    $and: [
      {
        title: 'Hello World',
      },
      {
        createdAt: { $gt: '2021-11-17T14:28:25.843Z' },
      },
    ],
  },
});
$and is used implicitly when passing an object with nested conditions:
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: 'Hello World',
    createdAt: { $gt: '2021-11-17T14:28:25.843Z' },
  },
});
$orβ
One or many nested conditions must be true.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    $or: [
      {
        title: 'Hello World',
      },
      {
        createdAt: { $gt: '2021-11-17T14:28:25.843Z' },
      },
    ],
  },
});
$notβ
Negates the nested conditions.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    $not: {
      title: 'Hello World',
    },
  },
});
$not can be used:
- as a logical operator (e.g. in where: { $not: { // conditions⦠}})
- or as an attribute operator (e.g. in where: { attribute-name: $not: { β¦ } }).
$and, $or and $not operators are nestable inside of another $and, $or or $not operator.
Attribute Operatorsβ
Using these operators may give different results depending on the database's implementation, as the comparison is handled by the database and not by Strapi.
$notβ
Negates nested condition(s).
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $not: {
        $contains: 'Hello World',
      },
    },
  },
});
$eqβ
Attribute equals input value.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $eq: 'Hello World',
    },
  },
});
$eq can be omitted:
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: 'Hello World',
  },
});
$eqiβ
Attribute equals input value (case-insensitive).
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $eqi: 'HELLO World',
    },
  },
});
$neβ
Attribute does not equal input value.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $ne: 'ABCD',
    },
  },
});
$neiβ
Attribute does not equal input value (case-insensitive).
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $nei: 'abcd',
    },
  },
});
$inβ
Attribute is contained in the input list.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $in: ['Hello', 'Hola', 'Bonjour'],
    },
  },
});
$in can be omitted when passing an array of values:
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: ['Hello', 'Hola', 'Bonjour'],
  },
});
$notInβ
Attribute is not contained in the input list.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $notIn: ['Hello', 'Hola', 'Bonjour'],
    },
  },
});
$ltβ
Attribute is less than the input value.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    rating: {
      $lt: 10,
    },
  },
});
$lteβ
Attribute is less than or equal to the input value.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    rating: {
      $lte: 10,
    },
  },
});
$gtβ
Attribute is greater than the input value.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    rating: {
      $gt: 5,
    },
  },
});
$gteβ
Attribute is greater than or equal to the input value.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    rating: {
      $gte: 5,
    },
  },
});
$betweenβ
Attribute is between the 2 input values, boundaries included (e.g., $between[1, 3] will also return 1 and 3).
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    rating: {
      $between: [1, 20],
    },
  },
});
$containsβ
Attribute contains the input value (case-sensitive).
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $contains: 'Hello',
    },
  },
});
$notContainsβ
Attribute does not contain the input value (case-sensitive).
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $notContains: 'Hello',
    },
  },
});
$containsiβ
Attribute contains the input value. $containsi is not case-sensitive, while $contains is.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $containsi: 'hello',
    },
  },
});
$notContainsiβ
Attribute does not contain the input value. $notContainsi is not case-sensitive, while $notContains is.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $notContainsi: 'hello',
    },
  },
});
$startsWithβ
Attribute starts with input value.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $startsWith: 'ABCD',
    },
  },
});
$endsWithβ
Attribute ends with input value.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $endsWith: 'ABCD',
    },
  },
});
$nullβ
Attribute is null.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $null: true,
    },
  },
});
$notNullβ
Attribute is not null.
Example
const entries = await strapi.db.query('api::article.article').findMany({
  where: {
    title: {
      $notNull: true,
    },
  },
});