---
title: Overview
noindex: true
---
**Legacy Docs:** This page describes our legacy API. It will be deprecated in
a future version. Please use the [v2 API](/) where possible.
Use `.` to search over text values nested inside JSON. For instance, the following query searches over a field with values like `{"metadata": {"color": "white"}}`.
```sql Function Syntax
SELECT description, rating, category
FROM mock_items
WHERE id @@@ paradedb.term('metadata.color', 'white');
```
```sql JSON Syntax
SELECT description, rating, category
FROM mock_items
WHERE id @@@
'{
"term": {
"field": "metadata.color",
"value": "white"
}
}'::jsonb;
```
The following query builder functions support JSON fields: [term](/legacy/advanced/term/term), [term set](/legacy/advanced/term/term-set), [fuzzy term](/legacy/advanced/term/fuzzy-term), [phrase](/legacy/advanced/phrase/phrase), [match](/legacy/advanced/full-text/match), [phrase prefix](/legacy/advanced/phrase/phrase-prefix), and [range](/legacy/advanced/term/range).
## Datetime Handling
When querying datetime values on JSON fields using JSON query syntax, always set `is_datetime: true` to ensure the query is parsed as a date.
```sql
SELECT id FROM mock_items WHERE mock_items @@@ '{
"range": {
"field": "metadata.attributes.tstz",
"lower_bound": {"included": "2023-05-01T08:12:34Z"},
"upper_bound": null,
"is_datetime": true
}
}'::jsonb
ORDER BY id;
```