mirror of
https://github.com/supabase/supabase.git
synced 2026-07-04 21:24:22 +08:00
147 lines
3.2 KiB
Plaintext
147 lines
3.2 KiB
Plaintext
---
|
|
id: plv8
|
|
title: 'plv8: JavaScript Language'
|
|
description: JavaScript language for PostgreSQL.
|
|
---
|
|
|
|
import Tabs from '@theme/Tabs'
|
|
import TabItem from '@theme/TabItem'
|
|
|
|
The `plv8` extension allows you use JavaScript within Postgres.
|
|
|
|
## Overview
|
|
|
|
While Postgres natively runs SQL, it can also run other "procedural languages".
|
|
`plv8` allows you to run JavaScript code - specifically any code that runs on the [V8 JavaScript engine](https://v8.dev).
|
|
|
|
It can be used for database functions, triggers, queries and more.
|
|
|
|
## Usage
|
|
|
|
### Enable the extension
|
|
|
|
<Tabs
|
|
defaultValue="dashboard"
|
|
values={[
|
|
{label: 'Dashboard', value: 'dashboard'},
|
|
{label: 'SQL', value: 'sql'},
|
|
]}>
|
|
|
|
<TabItem value="dashboard">
|
|
|
|
1. Go to the [Database](https://app.supabase.com/project/_/database/tables) page in the Dashboard.
|
|
2. Click on **Extensions** in the sidebar.
|
|
3. Search for "plv8" and enable the extension.
|
|
|
|
</TabItem>
|
|
<TabItem value="sql">
|
|
|
|
```sql
|
|
-- Example: enable the "plv8" extension
|
|
create extension plv8;
|
|
|
|
-- Example: disable the "plv8" extension
|
|
drop extension if exists plv8;
|
|
```
|
|
|
|
Even though the SQL code is `create extension`, this is the equivalent of "enabling the extension".
|
|
To disable an extension, call `drop extension`.
|
|
|
|
Procedural languages are automatically installed within `pg_catalog`, so you don't need to specify a schema.
|
|
|
|
</TabItem>
|
|
</Tabs>
|
|
|
|
### Create `plv8` functions
|
|
|
|
Functions written in `plv8` are written just like any other PostgreSQL functions, only
|
|
with the `language` identifier set to `plv8`.
|
|
|
|
```sql
|
|
create or replace function function_name()
|
|
returns void as $$
|
|
// V8 JavaScript
|
|
// code
|
|
// here
|
|
$$ language plv8;
|
|
```
|
|
|
|
You can call `plv8` functions like any other Postgres function:
|
|
|
|
<Tabs
|
|
defaultValue="sql"
|
|
values={[
|
|
{label: 'SQL', value: 'sql'},
|
|
{label: 'JavaScript', value: 'javascript'},
|
|
]}>
|
|
|
|
<TabItem value="sql">
|
|
|
|
```sql
|
|
select function_name();
|
|
```
|
|
|
|
</TabItem>
|
|
<TabItem value="javascript">
|
|
|
|
```js
|
|
const { data, error } = supabase.rpc('function_name')
|
|
```
|
|
|
|
</TabItem>
|
|
</Tabs>
|
|
|
|
## Examples
|
|
|
|
### Scalar functions
|
|
|
|
A [scalar function](https://plv8.github.io/#scalar-function-calls) is anything that takes in some user input and returns a single result.
|
|
|
|
```sql
|
|
create or replace function hello_world(name text)
|
|
returns text as $$
|
|
|
|
let output = `Hello, ${name}!`;
|
|
return output;
|
|
|
|
$$ language plv8;
|
|
```
|
|
|
|
### Executing SQL
|
|
|
|
You can execute SQL within `plv8` code using the [`plv8.execute` function](https://plv8.github.io/#plv8-execute).
|
|
|
|
```sql
|
|
create or replace function update_user(id bigint, first_name text)
|
|
returns smallint as $$
|
|
|
|
var num_affected = plv8.execute(
|
|
'update profiles set first_name = $1 where id = $2',
|
|
[first_name, id]
|
|
);
|
|
|
|
return num_affected;
|
|
$$ language plv8;
|
|
```
|
|
|
|
### Set-returning functions
|
|
|
|
A [set-returning function](https://plv8.github.io/#set-returning-function-calls) is anything that returns a full set of results - for example, rows in a table.
|
|
|
|
```sql
|
|
create or replace function get_messages()
|
|
returns setof messages as $$
|
|
|
|
var json_result = plv8.execute(
|
|
'select * from messages'
|
|
);
|
|
|
|
return json_result;
|
|
$$ language plv8;
|
|
```
|
|
|
|
## Resources
|
|
|
|
- Official [`plv8` documentation](https://plv8.github.io/)
|
|
- [plv8 GitHub Repository](https://github.com/plv8/plv8)
|