Skip to main content

System information functions

RisingWave provides functions to help you get system information, including database, schema, user, role, session, and more.

current_database()

Returns the name of the current database. You can use this function in SQL commands, functions, and operators.

current_database()*current_database_name*
SELECT current_database();`db_name`
SELECT count(current_database());1

current_role

Returns the name of the role that the current user is acting as, if the current user is a member of one or more roles.

current_role*current_role_name* 
current_role()*current_role_name*
SELECT current_role();'root'

current_shema

Returns the current schema. This is the schema that will be used for creating tables or other named objects without specifying a target schema.

current_schema*current_schema_name* 
current_schema()*current_schema_name*
SELECT current_schema();'public'

current_user

Returns the name of the current effective user.

current_user*user_name*
current_user()*user_name*
SELECT current_user();`root`

pg_get_viewdef()

Returns the definition of a specified view or materialized view.

pg_get_viewdef(view_name)text
-- Create a table
CREATE TABLE table1 (
id int PRIMARY KEY,
name VARCHAR
);

-- Create a materialized view
CREATE MATERIALIZED VIEW materialized_view1 AS
SELECT id, name
FROM table1;

-- Retrieve the definition of the materialized view using pg_get_viewdef
SELECT pg_get_viewdef('materialized_view1'::regclass);
----RESULT
SELECT id, name FROM table1
(1 row)

pg_typeof()

Returns the standard name of the data type of the provided value. More specifically, it returns the OID of the data type of the provided value. It returns a regtype, which is an OID alias type. Therefore it’s the same as an OID for comparison purposes but displays as a type name.

pg_typeof()regtype

SELECT pg_typeof(round(null));`double precision`
SELECT pg_typeof(row(true, 1, 'hello'));`record`
SELECT pg_typeof(array[1, 2]);`integer[]`

pg_relation_size

Computes the disk space used by one “fork” of the specified relation.

pg_relation_size ( relation regclass [, 'main' ] )bigint

Returns the size of the main data fork of the relation. This function can be used to determine if the main data fork of a relation exists. If its size is not 0, it means that the main data fork of the relation exists.

SELECT pg_relation_size('t') != 0;t
SELECT pg_relation_size('t', 'main') != 0;t

session_user

Returns the name of the current session user.

session_user*session_user_name*
session_user()*session_user_name*
SELECT session_user();`root`

user

Returns the name of the current database user.

user*user_name*
user()*user_name*
SELECT user();`root`

version()

Displays the PostgreSQL version and the RisingWave version implemented in the current instance of RisingWave.

SELECT version ();
---------RESULT
version
-----------------
PostgreSQL 8.3-RisingWave-1.0.0-alpha (76672d87cf5c20aa8fbb6f11996ef15255443b51)
(1 row)

Help us make this doc better!