ChatGPT解决这个技术问题 Extra ChatGPT

如何在 psql 中切换数据库?

在 MySQL 中,我使用了 use database_name;

psql 的等价物是什么?

好的,这是关于 psql,PostgreSQL 的前端?
MySQL“数据库”实际上是一个模式。因此,在大多数情况下,无论如何,MySQL 的“数据库”最好映射到 Postgres 中的模式。如果这样做了,您可以使用 set schema 'schema_name';set search_path to schema_name; 更改当前架构
模式通常在数据库下。

E
Erwin Brandstetter

在 PostgreSQL 中,您可以使用客户端工具 psql 的 \connect 元命令:

\connect DBNAME

或简而言之:

\c DBNAME

+1:这只是一个 psql 命令,在 Postgres 本身中,没有办法“切换”。事实上,psql 并不是在 MySQL 上下文中“切换”,只是关闭一个连接并打开另一个连接。
所以就没有机会用 SQL 来做吗?
那么这可以在 .sql 文件中的 SQL 语句中工作吗?例如,我可以让 CREATE DATABASE mydb; 后跟 \connect mydb 吗?
@Ciwan 我很确定您不能在 SQL 脚本文件中包含 psql 命令。
对于“切换”架构,请使用 set searchpath=schema_name
A
Asclepius

您可以使用 \c <database>\connect <database> 连接到数据库。


M
Michael Goldshteyn

在 PSQL 提示符下,您可以执行以下操作:

\connect (or \c) dbname

M
Manel Clos

使用 psql 连接时可以选择数据库。从脚本中使用它时这很方便:

sudo -u postgres psql -c "CREATE SCHEMA test AUTHORIZATION test;" test

谢谢,我疯了... :)
A
Anis KCHAOU

使用 \c databaseName\connect databaseName

(在 psql 13.3 上工作)


A
Ambrish Rajput

\l 用于数据库 \c DatabaseName 切换到 db \df 用于存储在特定数据库中的过程


F
Franck Dernoncourt

使用 psql 的元命令 \c or \connect [ dbname [ username ] [ host ] [ port ] ] | conninfo(参见 documentation)。

示例:\c MyDatabase

请注意,\c\connect 元命令是 case-sensitive


A
AlikElzin-kilaka

虽然问题中没有明确说明,但目的是连接到特定的模式/数据库。

另一种选择是直接连接到模式。例子:

sudo -u postgres psql -d my_database_name

来自 man psql 的来源:

-d dbname
--dbname=dbname
   Specifies the name of the database to connect to. This is equivalent to specifying dbname as the first non-option argument on the command line.

   If this parameter contains an = sign or starts with a valid URI prefix (postgresql:// or postgres://), it is treated as a conninfo string. See Section 31.1.1, “Connection Strings”, in the
   documentation for more information.

M
MediaVince

使用以下语句切换到驻留在您的 postgreSQL RDMS 中的不同数据库

\c databaseName

A
Abhishek

您还可以连接到具有不同 ROLE 的数据库,如下所示。

\connect DBNAME ROLENAME;

或者

\c DBNAME ROLENAME;

V
Vignesh Raja

如果要在启动时切换到特定数据库,请尝试

/Applications/Postgres.app/Contents/Versions/9.5/bin/psql vigneshdb;

默认情况下,Postgres 在端口 5432 上运行。如果它在另一个上运行,请确保在命令行中传递该端口。

/Applications/Postgres.app/Contents/Versions/9.5/bin/psql -p2345 vigneshdb;

通过一个简单的别名,我们可以方便地使用它。

在您的 .bashrc.bash_profile 中创建别名

function psql()
{
    db=vigneshdb
    if [ "$1" != ""]; then
            db=$1
    fi
    /Applications/Postgres.app/Contents/Versions/9.5/bin/psql -p5432 $1
}

在命令行中运行psql,它将切换到默认数据库; psql anotherdb,它将在启动时切换到参数中名称的数据库。


s
santosh tiwary

PostgreSQL 中列出和切换数据库 当您需要在数据库之间进行更改时,您将使用 \connect 命令,或 \c 后跟数据库名称,如下所示:

postgres=# \connect database_name
postgres=# \c database_name

检查您当前连接的数据库。

SELECT current_database();

PostgreSQL List Databases

postgres=# \l
 postgres=# \list

L
Lakhani Aliraza

您可以使用连接

\c 数据库名称

如果您想查看 POSTGRESQL 或 SQL 的所有可能命令,请按照以下步骤操作:

rails dbconsole(您将被重定向到当前的 ENV 数据库)? (对于 POSTGRESQL 命令)

或者

\h(对于 SQL 命令)按 Q 退出


v
vikash vishwakarma
  Connect to database:

  Method 1 : enter to db : sudo -u postgres psql

  Connect to db : \c dbname

  Method 2 : directly connect to db : sudo -u postgres psql -d my_database_name

v
vinzee

您只需输入 use [dbName] 即可在数据库之间切换而无需重新输入密码。


这不是 psql 中的有效语法(虽然它在 MySQL 中,但这是一个完全不同的数据库。