PostgreSQL psql 命令和常用的 SQL 语句整理

PostgreSQL psql 命令和常用的 SQL 语句整理

1、登录PostgreSQL数据库

在系统的命令行界面(如 Windows 的 cmd 或者 PowerShell、Linux 的终端等)中执行

sql 复制代码
-- 直接登录指定数据库:
psql -U postgres -d  database_name
或者
-- 不指定数据库则连接默认的postgres数据库:
psql -U postgres

2、psql 命令

sql 复制代码
-- 切换到指定数据库
\c database_name

-- 查询数据库列表
\l

-- 查询模式列表
\dn

-- 查看表结构
\d table_name

-- 查看所有表
\d

-- 查看指定模式下的所有表
\d schema_name.*

-- 查看客户端编码和服务器编码
SHOW client_encoding;
SHOW server_encoding;

-- 临时指定编码
SET client_encoding TO 'UTF8';

-- 临时设置模式
SET search_path TO public;

-- 执行脚本
\i 'E:/xxx_pg.sql'

-- 退出
\q

3、数据库操作

sql 复制代码
-- 创建数据库
CREATE DATABASE database_name;

-- 删除数据库
DROP DATABASE IF EXISTS database_name;

-- 查看数据库所有者
SELECT datname, pg_get_userbyid(datdba) FROM pg_database WHERE datname = 'database_name';

-- 修改数据库所有者
ALTER DATABASE database_name OWNER TO new_owner;

4、模式操作

sql 复制代码
-- 创建模式
CREATE SCHEMA schema_name;

-- 删除模式
DROP SCHEMA IF EXISTS schema_name CASCADE;

-- 查看模式所有者
SELECT nspname, pg_get_userbyid(nspowner) FROM pg_namespace WHERE nspname = 'public';

-- 修改模式所有者
ALTER SCHEMA schema_name OWNER TO new_owner;

5、表操作

sql 复制代码
-- 创建表
CREATE TABLE table_name (
    id SERIAL PRIMARY KEY,
    column1 datatype,
    column2 datatype
);

-- 删除表
DROP TABLE IF EXISTS table_name;

-- 修改表名
ALTER TABLE table_name RENAME TO new_table_name;

-- 添加列
ALTER TABLE table_name ADD COLUMN new_column datatype;

-- 删除列
ALTER TABLE table_name DROP COLUMN column_name;

-- 修改列的数据类型
ALTER TABLE table_name ALTER COLUMN column_name TYPE new_datatype;

-- 重命名列
ALTER TABLE table_name RENAME COLUMN column_name TO new_column_name;

6、数据操作

sql 复制代码
-- 插入数据
INSERT INTO table_name (column1, column2) VALUES (value1, value2);

-- 查询数据
SELECT * FROM table_name;
SELECT column1, column2 FROM table_name WHERE condition;

-- 更新数据
UPDATE table_name SET column1 = new_value WHERE condition;

-- 删除数据
DELETE FROM table_name WHERE condition;

7、索引操作

sql 复制代码
-- 创建索引
CREATE INDEX index_name ON table_name (column1);

-- 删除索引
DROP INDEX IF EXISTS index_name;

8、视图操作

sql 复制代码
-- 创建序列
CREATE SEQUENCE sequence_name;

-- 获取序列的下一个值
SELECT nextval('sequence_name');

-- 删除序列
DROP SEQUENCE IF EXISTS sequence_name;

9、权限操作

sql 复制代码
-- 授予用户对表的 SELECT 权限
GRANT SELECT ON table_name TO user_name;

-- 授予用户对模式的所有权限
GRANT ALL PRIVILEGES ON SCHEMA schema_name TO user_name;

-- 撤销用户对表的 INSERT 权限
REVOKE INSERT ON table_name FROM user_name;
相关推荐
倔强的石头_19 分钟前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou641 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1773 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再4 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest4 天前
数据库SQL学习
数据库·sql