PgSQL常用操作(命令)
连接数据库
使用username连接一个名为username的数据库(数据库与用户名同名,其余默认)
bash
psql -U username;
使用username登录名为dbname的数据库(其余默认)
bash
psql -U username -d dbname;
使用username登录名为username的数据库,且自定义用户名密码(其余默认)
bash
psql -U username -p port -h host;
使用username登录名为username的数据库,且需要输入密码(点回车键后输入密码,其余默认)
bash
psql -U username -W;
数据库操作
查看所有数据库:
postgresql
\l;
^等效于MySQL的:SHOW DATABASES^
进入某个数据库:
postgresql
\c dbname;
^等效于MySQL的:USE dbname^
删除数据库:
postgresql
DROP DATABASE [ IF EXISTS ] dbname;
^与MySQL等效^
创建数据库并将所有权给username用户:
postgresql
CREATE DATABASE db_name OWNER username;
Schema 操作
查看该库下所有Schema(需要在目标数据库下执行):
postgresql
SELECT * FROM information_schema.schemata;
查看某个Schema下的所有表(需要在目标数据库下执行):
postgresql
SELECT * FROM information_schema.tables WHERE table_schema='schema_name';
删除某个Schema(需要在目标数据库下执行):
postgresql
DROP SCHEMA IF EXISTS schema_name [CASCADE | RESTRICT];
- CASCADE:自动删除包含在模式中的对象(表、函数等等)
- RESTRICT:如果模式包含任何对象,则拒绝删除它。这个是缺省
修改Schema:
^重命名:^
postgresql
ALTER SCHEMA old_name RENAME TO new_name;
^更多修改如下:^
postgresql
ALTER SCHEMA schema_name
{
RENAME TO new_name |
OWNER TO new_owner |
QUOTA { quota [MB | GB | TB] | UNLIMITED }
}