tables postgres from example postgresql psql

postgresql - postgres - show schema psql



¿Cómo seleccionar un esquema en postgres cuando se usa psql? (7)

Tengo una base de datos postgres con múltiples esquemas. Cuando me conecto a la base de datos desde un shell con psql y ejecuto /dt , utiliza el esquema de conexión predeterminado que es público . ¿Hay una bandera que pueda especificar o cómo puedo cambiar el esquema?


¿Quieres cambiar la base de datos?

/l - to display databases /c - connect to new database

Actualizar.

He vuelto a leer tu pregunta. Para mostrar esquemas

/dn - list of schemas

Para cambiar el esquema, puedes intentar

SET search_path TO


En PostgreSQL, el sistema determina qué tabla se entiende siguiendo una ruta de búsqueda, que es una lista de esquemas para buscar.

Se considera que la primera tabla coincidente en la ruta de búsqueda es la deseada, de lo contrario, si no hay coincidencia, se genera un error, incluso si existen nombres de tabla coincidentes en otros esquemas en la base de datos.

Para mostrar la ruta de búsqueda actual, puede usar el siguiente comando:

SHOW search_path;

Y para poner el nuevo esquema en el camino, puede usar:

SET search_path TO myschema;

O si quieres múltiples esquemas:

SET search_path TO myschema, public;

Referencia: https://www.postgresql.org/docs/current/static/ddl-schemas.html


Esto es antiguo, pero puse exportaciones en mi alias para conectarse a la base de datos:

alias schema_one.con="PGOPTIONS=''--search_path=schema_one'' psql -h host -U user -d database etc"

Y para otro esquema:

alias schema_two.con="PGOPTIONS=''--search_path=schema_two'' psql -h host -U user -d database etc"


La solución rápida podría ser:

SELECT your_db_column_name from "your_db_schema_name"."your_db_tabel_name";


Utilice el nombre del esquema con punto en el comando psql para obtener información sobre este esquema.

Preparar:

test=# create schema test_schema; CREATE SCHEMA test=# create table test_schema.test_table (id int); CREATE TABLE test=# create table test_schema.test_table_2 (id int); CREATE TABLE

Mostrar lista de relaciones en test_schema :

test=# /dt test_schema. List of relations Schema | Name | Type | Owner -------------+--------------+-------+---------- test_schema | test_table | table | postgres test_schema | test_table_2 | table | postgres (2 rows)

Mostrar la definición test_schema.test_table :

test=# /d test_schema.test_table Table "test_schema.test_table" Column | Type | Modifiers --------+---------+----------- id | integer |

Mostrar todas las tablas en test_schema :

test=# /d test_schema. Table "test_schema.test_table" Column | Type | Modifiers --------+---------+----------- id | integer | Table "test_schema.test_table_2" Column | Type | Modifiers --------+---------+----------- id | integer |

etc ...


palabra clave:

SET search_path TO

ejemplo:

SET search_path TO your_schema_name;


/l - Display database /c - Connect to database /dn - List schemas /dt - List tables inside public schemas /dt schema1. - List tables inside particular schemas. For eg: ''schema1''.