PostgreSQL命令大全

news/2024/7/9 19:35:58 标签: postgresql, 数据库

文章目录

      • 连接与退出
      • 数据库操作
      • 表操作
      • 外键约束
      • 视图操作
      • 存储过程与函数
      • 权限管理
      • 事务管理
      • 查询优化与分析
      • 数据类型转换
      • 分区表操作
      • 复制与备份恢复

PostgreSQL是一个功能强大的开源关系型数据库管理系统,以下是一些基本且常用的命令按功能分类:

连接与退出

  • 连接数据库

    psql -U [username] -d [database]
    

    示例:以用户postgres身份连接到名为mydb的数据库

    psql -U postgres -d mydb
    
  • 退出 PostgreSQL Shell

    \q
    

数据库操作

  • 查看所有数据库

    \l
    
  • 创建数据库

    CREATE DATABASE [database_name];
    

    示例:

    CREATE DATABASE my_new_db;
    
  • 切换数据库

    \c [database_name]
    

    示例:

    \c my_new_db
    
  • 删除数据库

    DROP DATABASE [database_name];
    

    示例:

    DROP DATABASE unused_db;
    

表操作

  • 列出当前数据库中的表

    \dt
    
  • 创建表

    CREATE TABLE [table_name] (
      column1 data_type,
      column2 data_type,
      ...
    );
    

    示例:

    CREATE TABLE users (
      id SERIAL PRIMARY KEY,
      name VARCHAR(50),
      age INTEGER
    );
    
  • 查询表数据

    SELECT * FROM [table_name];
    

    示例:

    SELECT * FROM users;
    
  • 插入数据

    INSERT INTO [table_name] (column1, column2, ...) VALUES (value1, value2, ...);
    

    示例:

    INSERT INTO users (name, age) VALUES ('John Doe', 30);
    
  • 更新数据

    UPDATE [table_name] SET column1 = value1, column2 = value2 WHERE condition;
    

    示例:

    UPDATE users SET age = 31 WHERE name = 'John Doe';
    
  • 删除数据

    DELETE FROM [table_name] WHERE condition;
    

    示例:

    DELETE FROM users WHERE name = 'John Doe';
    
  • 创建索引

    CREATE INDEX [index_name] ON [table_name] (column1, column2);
    

    示例:

    CREATE INDEX idx_users_name ON users (name);
    
  • 删除索引

    DROP INDEX [index_name];
    

    示例:

    DROP INDEX idx_users_name;
    

当然,以下是更多PostgreSQL高级功能的命令示例:

外键约束

  • 创建具有外键约束的表
    CREATE TABLE orders (
      order_id SERIAL PRIMARY KEY,
      user_id INTEGER REFERENCES users(id) ON DELETE CASCADE
    );
    

视图操作

  • 创建视图

    CREATE VIEW [view_name] AS SELECT * FROM [table_name] WHERE condition;
    

    示例:

    CREATE VIEW active_users AS SELECT * FROM users WHERE is_active = true;
    
  • 查询视图

    SELECT * FROM [view_name];
    

    示例:

    SELECT * FROM active_users;
    
  • 更新或删除视图中的数据(通过视图修改原表数据)

    UPDATE [view_name] SET column1 = value1 WHERE condition;
    DELETE FROM [view_name] WHERE condition;
    
  • 删除视图

    DROP VIEW [view_name];
    

    示例:

    DROP VIEW active_users;
    

存储过程与函数

  • 创建存储过程

    CREATE OR REPLACE PROCEDURE my_procedure (IN param1 type, OUT param2 type)
    AS $$
    BEGIN
      -- 过程体
      SELECT some_column INTO param2 FROM some_table WHERE condition = param1;
    END;
    $$ LANGUAGE plpgsql;
    
  • 调用存储过程

    CALL my_procedure('value', OUT result);
    
  • 创建函数

    CREATE OR REPLACE FUNCTION my_function(param1 type)
    RETURNS type AS $$
    DECLARE
      result type;
    BEGIN
      SELECT some_column INTO result FROM some_table WHERE condition = param1;
      RETURN result;
    END;
    $$ LANGUAGE plpgsql;
    
  • 使用函数

    SELECT my_function('value') FROM dual;
    

权限管理

  • 授予用户权限

    GRANT privilege_type ON [table_name] TO [username];
    

    示例:

    GRANT SELECT, INSERT ON users TO new_user;
    
  • 撤销用户权限

    REVOKE privilege_type ON [table_name] FROM [username];
    

    示例:

    REVOKE ALL PRIVILEGES ON users FROM new_user;
    

事务管理

  • 开始事务

    BEGIN TRANSACTION;
    
  • 提交事务(确认所有更改):

    COMMIT;
    
  • 回滚事务(撤销所有更改):

    ROLLBACK;
    
  • 保存点设置(在事务中创建一个可以回滚到的点):

    SAVEPOINT [savepoint_name];
    

    示例:

    SAVEPOINT my_savepoint;
    
  • 回滚到保存点

    ROLLBACK TO [savepoint_name];
    

    示例:

    ROLLBACK TO my_savepoint;
    

查询优化与分析

  • 查看查询执行计划
    EXPLAIN [ANALYZE] [VERBOSE] [BUFFERS] [FORMAT type] SELECT ... ;
    
    示例:
    EXPLAIN ANALYZE SELECT * FROM users WHERE age > 30;
    

数据类型转换

  • 强制数据类型转换
    SELECT CAST(column AS new_type) FROM table;
    
    示例:
    SELECT CAST(age AS TEXT) FROM users;
    

分区表操作

  • 创建分区表(例如,按年份分区):
    CREATE TABLE sales (
      id SERIAL PRIMARY KEY,
      product VARCHAR(50),
      sale_date DATE
    ) PARTITION BY RANGE (sale_date);
    
    CREATE TABLE sales_2021 PARTITION OF sales
    FOR VALUES FROM ('2021-01-01') TO ('2022-01-01');
    

复制与备份恢复

  • 数据库备份

    pg_dump -U [username] -d [database] > backup.sql
    

    示例:

    pg_dump -U postgres -d mydb > mydb_backup.sql
    
  • 从备份恢复数据库

    psql -U [username] -d [database] < backup.sql
    

    示例:

    psql -U postgres -d mydb < mydb_backup.sql
    

以上是PostgreSQL数据库常用命令及使用案例的一部分,更多详细内容请参阅官方文档。对于大型应用和企业级环境,可能还需要涉及更复杂的集群配置、高可用性解决方案、性能调优等方面的知识。请参考官方文档以获取完整信息:https://www.postgresql.org/docs/current/index.html

python推荐学习汇总连接:
50个开发必备的Python经典脚本(1-10)

50个开发必备的Python经典脚本(11-20)

50个开发必备的Python经典脚本(21-30)

50个开发必备的Python经典脚本(31-40)

50个开发必备的Python经典脚本(41-50)
————————————————

​最后我们放松一下眼睛
在这里插入图片描述


http://www.niftyadmin.cn/n/5338303.html

相关文章

Python爬虫时被封IP,该怎么解决?四大动态IP平台测评

在使用 Python 进行爬虫时&#xff0c;很有可能因为一些异常行为被封 IP&#xff0c;这主要是因为一些爬虫时产生的异常行为导致的。 在曾经的一次数据爬取的时候&#xff0c;我尝试去爬取Google地图上面的商家联系方式和地址信息做营销&#xff0c;可是很不幸&#xff0c;还只…

CMU15-445-Spring-2023-分布式DBMS初探(lec21-24)

Lecture #21_ Introduction to Distributed Databases Distributed DBMSs 分布式 DBMS 将单个逻辑数据库划分为多个物理资源。应用程序&#xff08;通常&#xff09;并不知道数据被分割在不同的硬件上。系统依靠单节点 DBMS 的技术和算法来支持分布式环境中的事务处理和查询执…

ElasticSearch使用篇

目录 一、 概述 二、创建索引 三、查询索引 四、删除索引 五、修改索引 六、批量操作 6.1 批量写入 6.2 批量创建文档create 6.3 普通创建或全量替换index 6.4 批量删除delete 6.5 批量修改update 6.6 组合应用 6.7 批量读取 一、 概述 es的操作是基于 Restful 风格…

Druid监控 + 多数据源配置

application.yaml yaml配置文件的配置。 # 数据源配置 spring:datasource:type: com.alibaba.druid.pool.DruidDataSourcedriverClassName: com.mysql.cj.jdbc.Driverdruid:# ps# 主库数据源master:url: jdbc:mysql://localhost:3306/jzm?useUnicodetrue&characterEncod…

C# 程序结构

文章目录 前言一、C# 程序结构命名空间&#xff08;Namespace&#xff09;类&#xff08;Class&#xff09;方法&#xff08;Method&#xff09;语句&#xff08;Statement 二 、简单的C#程序结构示例示例代码分析第一个Hello World 程序总结 前言 C#基础学习入门系列- C# 程序…

kafka(一)——简介

简介 Kafka 是一种分布式、支持分区、多副本的消息中间件&#xff0c;支持发布-订阅模式&#xff0c;多用于实时处理大量数据缓存的场景&#xff0c;类似于一个“缓存池”。 架构 Producer&#xff1a;消息生产者&#xff1b;Consumer&#xff1a;消息消费者&#xff1b;Brok…

easydarwin 下面easywasmplayer和easyplayer

拷贝大佬们&#xff0c;起码验证能用再写文章&#xff0c;找到的各种坑 easydarwin/easywasmplayer - npm 区别 easyplayer&#xff1a;在与vue2结合的时候没有问题&#xff0c;但是用在vue3中&#xff0c;就是提示各种缺东西&#xff0c;你就是将所有文件引入到index.html都…

解决Unity WebGLInput插件全屏输入的问题

unity webgl的中文输入插件WebglInput在全屏的时候会出现无法输入中文/输入的英文会字母出现在光标后面/什么都输入不了的等无法正常使用的情况。 插件官网作者给出了unity的2017&#xff0c;2018&#xff0c;2019版本的全屏输入解决方法。 最新插件下载地址&#xff1a;http…