How to List Schemas In PostgreSQL?

6 minutes read

To list the schemas in PostgreSQL, you can execute a SQL query against the system catalog tables. Here is the query you can use:

1
2
SELECT schema_name
FROM information_schema.schemata;


This query retrieves the names of all the schemas available in the current database. The information_schema.schemata table contains information about all the schemas. By using the SELECT statement, you can fetch the schema_name column from this table.


Executing the query will return a result set containing the names of all the schemas in the database. Each row will represent a separate schema.


Please note that you need appropriate privileges to list the schemas.

Best Managed PostgreSQL Providers of January 2025

1
DigitalOcean

Rating is 5 out of 5

DigitalOcean

2
Vultr

Rating is 5 out of 5

Vultr

3
AWS

Rating is 5 out of 5

AWS

4
Cloudways

Rating is 4.9 out of 5

Cloudways


How to find the size of each schema in PostgreSQL?

To find the size of each schema in PostgreSQL, you can use the following query:

1
2
3
4
5
6
SELECT nspname AS schema_name,
  pg_size_pretty(pg_total_relation_size('"' || nspname || '"')) AS total_size
FROM pg_namespace
WHERE nspname NOT LIKE 'pg_%'
  AND nspname <> 'information_schema'
ORDER BY pg_total_relation_size('"' || nspname || '"') DESC;


This query retrieves the schema name and its total size by summing the sizes of all tables, indexes, and other objects within that schema. It also excludes system schemas like pg_% and information_schema.


To execute this query, you can use any PostgreSQL client or run it directly in the psql command-line tool.


What is the command line utility to list schemas in PostgreSQL?

The command line utility to list schemas in PostgreSQL is \dn.


How to export a list of all schemas in PostgreSQL to a file?

To export a list of all schemas in PostgreSQL to a file, you can use the following steps:

  1. Open a terminal or command prompt.
  2. Connect to the PostgreSQL database using the psql command-line tool with the appropriate credentials:
1
psql -U <username> -h <hostname> -p <port> -d <database_name>


Replace <username>, <hostname>, <port>, and <database_name> with your specific database credentials.

  1. Once connected to the database, execute the following command to generate and save the list of schemas to a file:
1
2
3
4
5
6
\o /path/to/output_file.txt    # Set the output file

SELECT nspname
FROM pg_namespace
WHERE nspname not like 'pg_%' AND nspname != 'information_schema'   -- Exclude system schemas
ORDER BY nspname;


Replace /path/to/output_file.txt with the actual path and filename where you want to save the list of schemas.

  1. To stop recording the output in the file, use the following command:
1
\o


This will reset the output to the default console.


After completing these steps, you should have a file (output_file.txt) containing the list of all schemas in PostgreSQL.


What is the syntax to list schemas along with their associated privileges in PostgreSQL?

To list schemas along with their associated privileges in PostgreSQL, you can use the following query:

1
2
3
4
5
SELECT nspname AS schema_name,
       relacl AS privileges
FROM pg_namespace
LEFT JOIN pg_catalog.pg_namespace ON pg_namespace.oid = pg_attribute.attrelid
WHERE nspname NOT LIKE 'pg_%' AND nspname != 'information_schema';


This query retrieves the schema name (nspname) from the pg_namespace catalog table and also retrieves the associated privileges (relacl) from the pg_attribute catalog table, which stores the access control list (ACL) for tables and other relation types.


The LEFT JOIN in the query ensures that even if a schema doesn't have any privileges associated with it, it will still be included in the result set. The WHERE clause filters out any built-in system schemas like pg_% and information_schema.


How to check if a specific schema exists in PostgreSQL?

You can use a SQL query to check if a specific schema exists in PostgreSQL. Here is an example of how to do it:

1
2
3
4
5
SELECT EXISTS (
    SELECT 1
    FROM pg_namespace
    WHERE nspname = 'your_schema_name'
);


Replace 'your_schema_name' with the name of the schema you want to check. The query will return true if the schema exists and false if it doesn't.


How to query for a list of schemas in PostgreSQL?

To query for a list of schemas in PostgreSQL, you can use the following command:

1
2
SELECT schema_name 
FROM information_schema.schemata;


This query selects the schema_name column from the schemata table in the information_schema schema.


If you want to filter the list of schemas based on some conditions, you can add a WHERE clause to the query. For example, to only retrieve the schemas that start with the letter "p", you can use the following query:

1
2
3
SELECT schema_name 
FROM information_schema.schemata
WHERE schema_name LIKE 'p%';


This will return only the schemas whose names start with the letter "p". You can modify the WHERE clause to suit your specific filtering criteria.

Facebook Twitter LinkedIn Whatsapp Pocket

Related Posts:

To loop over a list of schemas in PostgreSQL, you can use PL/pgSQL (a procedural language available in PostgreSQL) to write a script. Here&#39;s an example of how you can achieve this:Create a function in PL/pgSQL by using the CREATE OR REPLACE FUNCTION statem...
To create a read-only user in Azure PostgreSQL, you can first connect to your PostgreSQL database using a superuser account. Once connected, you can then create a new user with the desired read-only permissions. When creating the user, you will need to specify...
To append a list of lists in Groovy, you can use the &#34;addAll&#34; method to add all the elements of one list to another. This can be done by calling the &#34;addAll&#34; method on the target list and passing the list of lists as a parameter. This will appe...