mirror of
https://github.com/supabase/supabase.git
synced 2026-06-23 19:48:02 +08:00
288 lines
9.4 KiB
Plaintext
288 lines
9.4 KiB
Plaintext
---
|
|
id: json
|
|
title: 'JSON'
|
|
description: Using the JSON data type in PostgreSQL.
|
|
---
|
|
|
|
import Tabs from '@theme/Tabs'
|
|
import TabItem from '@theme/TabItem'
|
|
|
|
PostgreSQL supports [JSON functions and operators](https://www.postgresql.org/docs/current/functions-json.html) which gives flexibility when storing data inside a database column.
|
|
|
|
PostgreSQL supports two types of JSON columns: `JSON` and `JSONB`.
|
|
The recommended type is `JSONB` for almost all cases.
|
|
When you use the `JSONB` format, the data is parsed when it's put into the database so it's faster when querying and also it can be indexed.
|
|
|
|
## Create a table with a JSON column
|
|
|
|
<Tabs
|
|
groupId="json"
|
|
defaultValue="dashboard"
|
|
values={[
|
|
{label: 'Dashboard', value: 'dashboard'},
|
|
{label: 'SQL', value: 'sql'},
|
|
]}>
|
|
|
|
<TabItem value="dashboard">
|
|
|
|
1. Go to the [Table Editor](https://app.supabase.com/project/_/editor) page in the Dashboard.
|
|
2. Click **New Table** and create a table called `books`.
|
|
3. Include a primary key with the following properties:
|
|
- Name: `id`
|
|
- Type: `int8`
|
|
- Default value: `Automatically generate as indentity`
|
|
4. Click **Save**.
|
|
5. Click **New Column** and add 3 columns with the following properties:
|
|
- **title** column
|
|
- Name: `title`
|
|
- Type: `text`
|
|
- **author** column
|
|
- Name: `author`
|
|
- Type: `text`
|
|
- **metadata** column
|
|
- Name: `metadata`
|
|
- Type: `jsonb`
|
|
|
|
</TabItem>
|
|
|
|
<TabItem value="sql">
|
|
|
|
```sql
|
|
create table books (
|
|
id serial primary key,
|
|
title text,
|
|
author text,
|
|
metadata jsonb
|
|
);
|
|
```
|
|
|
|
</TabItem>
|
|
</Tabs>
|
|
|
|
## Insert data into the table
|
|
|
|
<Tabs
|
|
groupId="json"
|
|
defaultValue="dashboard"
|
|
values={[
|
|
{label: 'Dashboard', value: 'dashboard'},
|
|
{label: 'SQL', value: 'sql'},
|
|
{label: 'JavaScript', value: 'javascript'},
|
|
]}>
|
|
|
|
<TabItem value="dashboard">
|
|
|
|
1. Go to the [Table Editor](https://app.supabase.com/project/_/editor) page in the Dashboard.
|
|
2. Select the `books` table in the sidebar.
|
|
3. Click **+ Insert row** and add 5 rows with the following properties:
|
|
|
|
| id | title | author | metadata |
|
|
| --- | ----------------------------------- | ---------------------- | -------------------------------------------------------------------------------------------------------------- |
|
|
| 1 | The Poky Little Puppy | Janette Sebring Lowrey | {"ages":[3,6],"price":5.95,"description":"Puppy is slower than other, bigger animals."} |
|
|
| 2 | The Tale of Peter Rabbit | Beatrix Potter | {"ages":[2,5],"price":4.49,"description":"Rabbit eats some vegetables."} |
|
|
| 3 | Tootle | Gertrude Crampton | {"ages":[2,5],"price":3.99,"description":"Little toy train has big dreams."} |
|
|
| 4 | Green Eggs and Ham | Dr. Seuss | {"ages":[4,8],"price":7.49,"description":"Sam has changing food preferences and eats unusually colored food."} |
|
|
| 5 | Harry Potter and the Goblet of Fire | J.K. Rowling | {"ages":[10,99],"price":24.95,"description":"Fourth year of school starts, big drama ensues."} |
|
|
|
|
</TabItem>
|
|
|
|
<TabItem value="sql">
|
|
|
|
```sql
|
|
insert into books
|
|
(title, author, metadata)
|
|
values
|
|
(
|
|
'The Poky Little Puppy',
|
|
'Janette Sebring Lowrey',
|
|
'{"description":"Puppy is slower than other, bigger animals.","price":5.95,"ages":[3,6]}'
|
|
),
|
|
(
|
|
'The Tale of Peter Rabbit',
|
|
'Beatrix Potter',
|
|
'{"description":"Rabbit eats some vegetables.","price":4.49,"ages":[2,5]}'
|
|
),
|
|
(
|
|
'Tootle',
|
|
'Gertrude Crampton',
|
|
'{"description":"Little toy train has big dreams.","price":3.99,"ages":[2,5]}'
|
|
),
|
|
(
|
|
'Green Eggs and Ham',
|
|
'Dr. Seuss',
|
|
'{"description":"Sam has changing food preferences and eats unusually colored food.","price":7.49,"ages":[4,8]}'
|
|
),
|
|
(
|
|
'Harry Potter and the Goblet of Fire',
|
|
'J.K. Rowling',
|
|
'{"description":"Fourth year of school starts, big drama ensues.","price":24.95,"ages":[10,99]}'
|
|
);
|
|
```
|
|
|
|
</TabItem>
|
|
|
|
<TabItem value="javascript">
|
|
|
|
```js
|
|
const { data, error } = await supabase.from('books').insert([
|
|
{
|
|
title: 'The Poky Little Puppy',
|
|
author: 'Janette Sebring Lowrey',
|
|
metadata: {
|
|
description: 'Puppy is slower than other, bigger animals.',
|
|
price: 5.95,
|
|
ages: [3, 6],
|
|
},
|
|
},
|
|
{
|
|
title: 'The Tale of Peter Rabbit',
|
|
author: 'Beatrix Potter',
|
|
metadata: {
|
|
description: 'Rabbit eats some vegetables.',
|
|
price: 4.49,
|
|
ages: [2, 5],
|
|
},
|
|
},
|
|
{
|
|
title: 'Tootle',
|
|
author: 'Gertrude Crampton',
|
|
metadata: {
|
|
description: 'Little toy train has big dreams.',
|
|
price: 3.99,
|
|
ages: [2, 5],
|
|
},
|
|
},
|
|
{
|
|
title: 'Green Eggs and Ham',
|
|
author: 'Dr. Seuss',
|
|
metadata: {
|
|
description:
|
|
'Sam has changing food preferences and eats unusually colored food.',
|
|
price: 7.49,
|
|
ages: [4, 8],
|
|
},
|
|
},
|
|
{
|
|
title: 'Harry Potter and the Goblet of Fire',
|
|
author: 'J.K. Rowling',
|
|
metadata: {
|
|
description: 'Fourth year of school starts, big drama ensues.',
|
|
price: 24.95,
|
|
ages: [10, 99],
|
|
},
|
|
},
|
|
])
|
|
```
|
|
|
|
</TabItem>
|
|
</Tabs>
|
|
|
|
## View the data
|
|
|
|
<Tabs
|
|
groupId="json"
|
|
defaultValue="sql"
|
|
values={[
|
|
{label: 'SQL', value: 'sql'},
|
|
{label: 'JavaScript', value: 'javascript'},
|
|
{label: 'Result', value: 'result'},
|
|
]}>
|
|
|
|
<TabItem value="sql">
|
|
|
|
```sql
|
|
select *
|
|
from books;
|
|
```
|
|
|
|
</TabItem>
|
|
|
|
<TabItem value="javascript">
|
|
|
|
```js
|
|
const { data, error } = await supabase.from('books').select('*')
|
|
console.log(JSON.stringify(data, null, 2))
|
|
```
|
|
|
|
</TabItem>
|
|
|
|
<TabItem value="result">
|
|
|
|
| id | title | author | metadata |
|
|
| --- | ----------------------------------- | ---------------------- | -------------------------------------------------------------------------------------------------------------- |
|
|
| 1 | The Poky Little Puppy | Janette Sebring Lowrey | {"ages":[3,6],"price":5.95,"description":"Puppy is slower than other, bigger animals."} |
|
|
| 2 | The Tale of Peter Rabbit | Beatrix Potter | {"ages":[2,5],"price":4.49,"description":"Rabbit eats some vegetables."} |
|
|
| 3 | Tootle | Gertrude Crampton | {"ages":[2,5],"price":3.99,"description":"Little toy train has big dreams."} |
|
|
| 4 | Green Eggs and Ham | Dr. Seuss | {"ages":[4,8],"price":7.49,"description":"Sam has changing food preferences and eats unusually colored food."} |
|
|
| 5 | Harry Potter and the Goblet of Fire | J.K. Rowling | {"ages":[10,99],"price":24.95,"description":"Fourth year of school starts, big drama ensues."} |
|
|
|
|
The data as it appears here has the `JSONB` fields in a different order than when inserted. As mentioned earlier, data is parsed as its inserted when using the JSONB format.
|
|
|
|
</TabItem>
|
|
</Tabs>
|
|
|
|
## Query the `JSONB` data
|
|
|
|
Select the title, description, price, and age range for each book.
|
|
|
|
<Tabs
|
|
groupId="json"
|
|
defaultValue="sql"
|
|
values={[
|
|
{label: 'SQL', value: 'sql'},
|
|
{label: 'JavaScript', value: 'javascript'},
|
|
{label: 'Result', value: 'result'}
|
|
]}>
|
|
|
|
<TabItem value="sql">
|
|
|
|
```sql
|
|
select
|
|
title,
|
|
metadata -> 'description' AS description,
|
|
metadata -> 'price' as price,
|
|
metadata -> 'ages' -> 0 as low_age,
|
|
metadata -> 'ages' -> 1 as high_age
|
|
from
|
|
books;
|
|
```
|
|
|
|
</TabItem>
|
|
|
|
<TabItem value="javascript">
|
|
|
|
```js
|
|
const { data, error } = await supabase
|
|
.from('books')
|
|
.select(
|
|
'title,description:metadata->description,price:metadata->price,low_age:metadata->ages->0,high_age:metadata->ages->1'
|
|
)
|
|
console.log(JSON.stringify(data, null, 2))
|
|
```
|
|
|
|
</TabItem>
|
|
|
|
<TabItem value="result">
|
|
|
|
| title | description | price | low_age | high_age |
|
|
| ----------------------------------- | ------------------------------------------------------------------ | ----- | ------- | -------- |
|
|
| The Poky Little Puppy | Puppy is slower than other, bigger animals. | 5.95 | 3 | 6 |
|
|
| The Tale of Peter Rabbit | Rabbit eats some vegetables. | 4.49 | 2 | 5 |
|
|
| Tootle | Little toy train has big dreams. | 3.99 | 2 | 5 |
|
|
| Green Eggs and Ham | Sam has changing food preferences and eats unusually colored food. | 7.49 | 4 | 8 |
|
|
| Harry Potter and the Goblet of Fire | Fourth year of school starts, big drama ensues. | 24.95 | 10 | 99 |
|
|
|
|
</TabItem>
|
|
</Tabs>
|
|
|
|
Note that the `->` operator returns JSONB data. If you want TEXT/STRING data returned, use the `->>` operator.
|
|
|
|
- metadata -> 'description' (returns a JSON object)
|
|
- metadata ->> 'description' (returns STRING/TEXT data)
|
|
|
|
## Resources
|
|
|
|
- [Supabase JS Client](https://github.com/supabase/supabase-js)
|
|
- [PostgreSQL: JSON Functions and Operators](https://www.postgresql.org/docs/12/functions-json.html)
|
|
- [PostgreSQL JSON types](https://www.postgresql.org/docs/12/datatype-json.html)
|