mirror of
https://github.com/supabase/supabase.git
synced 2026-07-06 00:04:23 +08:00
304 lines
10 KiB
Plaintext
304 lines
10 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 flexiblity 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.
|
|
|
|
## Steps
|
|
|
|
### Create a table with a JSON column.
|
|
|
|
<Tabs
|
|
defaultValue="SQL"
|
|
values={[
|
|
{label: 'SQL', value: 'SQL'},
|
|
{label: 'UI', value: 'UI'},
|
|
]}>
|
|
<TabItem value="SQL">
|
|
|
|
```sql
|
|
create table books (
|
|
id serial primary key,
|
|
title text,
|
|
author text,
|
|
metadata jsonb
|
|
);
|
|
```
|
|
|
|
</TabItem>
|
|
<TabItem value="UI">
|
|
|
|
```sh
|
|
Create the table:
|
|
|
|
1. Go to the Table Editor
|
|
2. Click "New Table"
|
|
3. Name the table "books"
|
|
4. Include a primary key with the following properties:
|
|
- Name: "id"
|
|
- Type: "int8"
|
|
- Default value: "Automatically generate as indentity"
|
|
5. Click "Save"
|
|
|
|
|
|
Click "New Column" and 3 new columns with the following properties:
|
|
|
|
1. title column:
|
|
- Name: "title"
|
|
- Type: "text"
|
|
|
|
2. author column:
|
|
- Name: "author"
|
|
- Type: "text"
|
|
|
|
3. metadata column:
|
|
- Name: "metadata"
|
|
- Type: "jsonb"
|
|
```
|
|
|
|
</TabItem>
|
|
</Tabs>
|
|
|
|
### Insert data into the table.
|
|
|
|
<Tabs
|
|
defaultValue="Data"
|
|
values={[
|
|
{label: 'Data', value: 'Data'},
|
|
{label: 'SQL', value: 'SQL'},
|
|
{label: 'UI', value: 'UI'},
|
|
{label: 'JS', value: 'JavaScript'},
|
|
]}>
|
|
<TabItem value="Data">
|
|
|
|
| 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 unusally 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 unusally 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="UI">
|
|
|
|
```bash
|
|
- click `Table Editor`
|
|
- click `books`
|
|
- click `+ Insert Row`
|
|
- `title`: `The Poky Little Puppy`
|
|
- `author`: 'Janette Sebring Lowrey'
|
|
- `metadata`: {"description":"Puppy is slower than other, bigger animals.","price":5.95,"ages":[3,6]}
|
|
- click `Save`
|
|
- click `+ Insert Row`
|
|
- `title`: `The Tale of Peter Rabbit`
|
|
- `author`: 'Beatrix Potter'
|
|
- `metadata`: {"ages":[2,5],"price":4.49,"description":"Rabbit eats some vegetables."}
|
|
- click `Save`
|
|
- click `+ Insert Row`
|
|
- `title`: `Tootle`
|
|
- `author`: 'Gertrude Crampton'
|
|
- `metadata`: {"ages":[2,5],"price":3.99,"description":"Little toy train has big dreams."}
|
|
- click `Save`
|
|
- click `+ Insert Row`
|
|
- `title`: `Green Eggs and Ham`
|
|
- `author`: 'Dr. Seuss'
|
|
- `metadata`: {"ages":[4,8],"price":7.49,"description":"Sam has changing food preferences and eats unusally colored food."}
|
|
- click `Save`
|
|
- click `+ Insert Row`
|
|
- `title`: `Harry Potter and the Goblet of Fire`
|
|
- `author`: 'J.K. Rowling'
|
|
- `metadata`: {"ages":[10,99],"price":24.95,"description":"Fourth year of school starts, big drama ensues."}
|
|
- click `Save`
|
|
```
|
|
|
|
</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 unusally 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
|
|
defaultValue="SQL"
|
|
values={[
|
|
{label: 'SQL', value: 'SQL'},
|
|
{label: 'JS', value: 'JavaScript'},
|
|
{label: 'Data', value: 'Data'},
|
|
]}>
|
|
<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="Data">
|
|
|
|
| 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 unusally 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."} |
|
|
|
|
NOTICE: The data as it appears here will have the `JSONB` fields in a different order than when we inserted them.
|
|
As we said earlier about the differences between the `JSON` and `JSONB` fields:
|
|
>When you use the `JSONB` format, the data is parsed when it's put into the database...
|
|
|
|
</TabItem>
|
|
</Tabs>
|
|
|
|
### Query the `JSONB` data.
|
|
|
|
#### Select title, description, price, and age range for each book.
|
|
|
|
<Tabs
|
|
defaultValue="SQL"
|
|
values={[
|
|
{label: 'SQL', value: 'SQL'},
|
|
{label: 'JS', value: 'JavaScript'},
|
|
{label: 'Results', value: 'Results'}
|
|
]}>
|
|
<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="Results">
|
|
|
|
| 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 unusally 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>
|
|
|
|
|
|
|
|
|
|
#### Data Types
|
|
One last thing to note: the -> operator returns JSONB data. If you want TEXT/STRING data returned, you need to use the ->> operator.
|
|
|
|
- metadata -> 'description' (this returns a JSON object)
|
|
- metadata ->> 'description' (this returns STRING/TEXT data)
|
|
|
|
## Resources
|
|
|
|
* [Supabase Account - Free Tier OK](https://supabase.io)
|
|
* [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)
|