Skip to content

Conversation

nazarpechka
Copy link
Contributor

@nazarpechka nazarpechka commented Jun 30, 2025

This PR introduces two new operators for filtering on array-typed PostgreSQL columns.

  • $contains_any: matches rows whose array contains any of the given values
  • $contains_none: matches rows whose array contains none of the given values

Both of those operators accept List[str] | List[int] | List[float] | str | float | int.
User should assure that input has the same type as the underlying PostgreSQL column.

Examples of usage:

# find docs tagged “audio” or “hydration”
{"tags": {"$contains_any": ["audio", "hydration"]}}

# exclude docs with those tags
{"tags": {"$contains_none": ["audio", "hydration"]}}

# multi‐column combo
{
  "$and": [
    {"dimensions": {"$contains_any": 25.0}},
    {"is_available": True}
  ]
}

Inspired by #146

@nazarpechka nazarpechka changed the title feat: add $contains_any and $contains_none operators for filtering feat: $contains_any and $contains_none operators for array-inclusion filtering Jun 30, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant