
PostgreSQL教程(2)客户端工具psql的使用
一、命令行客户端
psql 是 PostgreSQL 的命令行客户端工具,类似于MySQL中的mysql、Oracle中的sqlplus。通过psql可以实现对 PostgreSQL 数据库的连接和各种管理工作,比如远程登录数据库、 执行 SQL 脚本、实现用户权限管理等
1、psql 语法格式
#psql语法格式 psql -h <主机名或IP地址> -p <端口> [数据库名] [用户名] #非交互模式,使用-f选项可以在连接数据库后执行指定的脚本 psql -h <主机名或IP地址> -p <端口> [数据库名] [用户名] -f test.sql
2、psql 常用命令
\l:查看当前实例中的数据库,类似mysql中的show databases
\c:查看当前数据库或者切换到指定数据库
\d:显示当前数据库中所有表、索引、视图等,如果接上表名可以显示该表结构、接上索引名则显示索引信息,支持通配符模糊匹配
\d+:比\d显示更多信息
\dn:显示所有模式
\db:显示所有表空间信息
\du:显示所有角色或用户
\dp:显示分配的权限信息
\x:将查询结果单行显示,适用于列多而显示不全的场景
\timing on:显示SQL执行时间
\i file:执行指定的SQL脚本
\q:退出psql
3、psql 用例
· 连接数据库
psql -h 192.168.0.103 -p 5432 -d tanglu_database -U tanglu #-U:指定用户名 #-W:进行交互式密码验证 #-w:非交互式登录 #-p:指定服务端口 #-h:指定服务地址 #-d:指定连接数据库,默认为postgres #-f:登录时同时指定指定的sql文件,类似mysql -e #连接参数也可以用环境变量指定,这样就不用每次手写参数 export PGDATABASE=tanglu_database export PGHOST=192.168.0.103 export PGPORT=5432 export PGDUSER=postgres
· 查看帮助
通过 \? 可以查看所有psql子命令的用法,如果忘记了某个对象管理的命令可以通过这个帮助进行查看
· 查看连接信息
通过 \conninfo 可以查看当前用户与数据库的连接情况,类似操作系统 who 命令
postgres=# \conninfo
You are connected to database "postgres" as user "postgres" via socket in "/run/postgresql" at port "5432".
· 切换数据库
#没有指定库名会直接显示当前连接情况 postgres=# \c You are now connected to database "postgres" as user "postgres". #使用\c切换到指定库 postgres=# \c tanglu_database; You are now connected to database "tanglu_database" as user "postgres". #同时切换数据库和用户 postgres=# \c tanglu_database tanglu; You are now connected to database "tanglu_database" as user "tanglu".
· 列出实例中所有数据库
tanglu_database=# \l List of databases Name | Owner | Encoding | Collate | Ctype | Access privileges -----------------+----------+----------+-------------+-------------+----------------------- postgres | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | tanglu_database | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | template0 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres + | | | | | postgres=CTc/postgres template1 | postgres | UTF8 | en_US.UTF-8 | en_US.UTF-8 | =c/postgres + | | | | | postgres=CTc/postgres (4 rows)
· 显示当前数据库中的表
通过 \dt 显示当前数据库中的表,display table
tanglu_database=# \dt List of relations Schema | Name | Type | Owner --------+------+-------+---------- public | t1 | table | postgres public | t2 | table | postgres public | t3 | table | postgres
· 查看当前库所有表的详细信息
通过 \d+打印出数据库表的详细信息,包含表大小、属主等
tanglu_database=# \d+ List of relations Schema | Name | Type | Owner | Persistence | Access method | Size | Description --------+------+-------+----------+-------------+---------------+---------+------------- public | t1 | table | postgres | permanent | heap | 0 bytes | public | t2 | table | postgres | permanent | heap | 0 bytes | public | t3 | table | postgres | permanent | heap | 0 bytes | (3 rows)
· 查看表结构
tanglu_database=# \d t1; Table "public.t1" Column | Type | Collation | Nullable | Default --------+-----------------------+-----------+----------+--------- id | integer | | | name | character varying(10) | | |
· 查看索引
通过 \di 打印指定表的索引信息,display index
tanglu_database=# \di
· 查看用户或者角色信息
通过\du 打印用户和权限信息,display user
tanglu_database=# \du List of roles Role name | Attributes | Member of -----------+------------------------------------------------------------+----------- postgres | Superuser, Create role, Create DB, Replication, Bypass RLS | {}
· 查看PGSQL所支持的参数
类似show variables,同样支持通配符
tanglu_database=# \df *size*
· 导入SQL文件
tanglu_database=# \i test.sql test.sql: No such file or directory
· 导出查询结果到本地
#该查询结果都会存储到test.sql中 tanglu_database=# \o test.sql select * from t1 where id >10;
· 查看SQL执行时长
tanglu_database=# \timing select * from t1; Time: 202.372ms
· 查看数据库参数配置
postgres=# show $具体参数名 postgres=# show maintenance_work_mem
二、图形化客户端
PostgreSQL官方提供了一款图形化管理工具pgAdmin,官网下载地址为https://www.pgadmin.org/download/。在安装Windows版的PGSQL时也可以勾选安装该工具pgAdmin,该工具安装后的使用方式类似SQLyog等工具,并且进行了汉化
猜你喜欢

PostgreSQL PostgreSQL教程(7)用户权限与角色管理
一、PostgreSQL 用户与权限介绍· 用户:用于访问和管理 PostgreSQL 数据库中的各种对象。按照数据库使用规范,建议为每一个数据库用户分配合适的权限,避免因权限过大而产生数据泄露、丢失...

PostgreSQL PostgreSQL教程(6)VACUUM碎片清理与并行查询特性
一、VACUUM 机制介绍1、VACUUM作用VACUUM是PostgreSQL中的碎片维护机制,用于清理和回收无效数据。由于 PostgreSQL 的 MVCC 机制实现原理与MySQL不同,它并不...

PostgreSQL PostgreSQL教程(5)访问控制文件 pb_hba.conf 说明与配置
一、PostgreSQL客户端认证说明pb_hba.conf 用于实现PGSQL的访问控制,通过该文件可以实现基于主机的认证,其作用类似于操作系统的防火墙,通过认证配置来控制允许哪些主机、哪些用户可以...

MySQL MySQL教程(9)视图、触发器与存储过程
一、数据库视图数据库视图是将查询语句进行封装而形成的虚拟表,这些虚拟表可以用于正常的查询和修改操作1、视图的应用场景· 将复杂的查询语句进行封装,简化查询命令· 可以灵活的对一些敏感表中的特定字段进行...

MySQL MySQL教程(8)存储引擎原理与日志机制
一、MySQL存储引擎介绍数据库存储引擎可以理解为是数据库的文件系统,MySQL主要存储引擎有MyISAM、InnoDB、Memory、TokuDB、CSV等。存储引擎位于表级别,通过不同的存储引擎来...
文章评论