PostgreSQL 的使用介绍

PostgreSQL 是一个功能强大的开源关系型数据库管理系统(RDBMS),以其稳定性、灵活性和对复杂查询的支持而闻名。以下是 PostgreSQL 的使用和关键知识点介绍:


1. 安装和配置

安装
  • Linux :通过包管理器(如 aptyum)安装。

    bash 复制代码
    sudo apt update
    sudo apt install postgresql postgresql-contrib
  • Windows/MacOS :使用 PostgreSQL 官网提供的安装包或工具(如 Homebrew)。

    bash 复制代码
    brew install postgresql
启动与管理
  • 启动服务:

    bash 复制代码
    sudo service postgresql start
  • 登录默认数据库:

    bash 复制代码
    psql -U postgres
  • 创建新数据库:

    sql 复制代码
    CREATE DATABASE mydb;

2. 基础操作

连接数据库
  • 使用 psql 命令行工具:

    bash 复制代码
    psql -U username -d databasename
  • 通过编程语言(如 Python、Java、Node.js)连接,需安装相应驱动程序(如 psycopg2、JDBC)。

常用 SQL 操作
  1. 创建表

    sql 复制代码
    CREATE TABLE users (
        id SERIAL PRIMARY KEY,
        name VARCHAR(100),
        email VARCHAR(150),
        created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
    );
  2. 插入数据

    sql 复制代码
    INSERT INTO users (name, email) VALUES ('Alice', 'alice@example.com');
  3. 查询数据

    sql 复制代码
    SELECT * FROM users;
  4. 更新数据

    sql 复制代码
    UPDATE users SET email = 'newemail@example.com' WHERE id = 1;
  5. 删除数据

    sql 复制代码
    DELETE FROM users WHERE id = 1;

3. 高级功能

事务和并发控制

PostgreSQL 支持 ACID 事务:

sql 复制代码
BEGIN;
UPDATE accounts SET balance = balance - 100 WHERE id = 1;
UPDATE accounts SET balance = balance + 100 WHERE id = 2;
COMMIT;
  • 若中途发生错误,可用 ROLLBACK 撤销事务。
高级查询
  • 窗口函数

    sql 复制代码
    SELECT name, salary, RANK() OVER (ORDER BY salary DESC) AS rank
    FROM employees;
  • CTE(公用表表达式)

    sql 复制代码
    WITH cte AS (
        SELECT id, name FROM users WHERE name LIKE 'A%'
    )
    SELECT * FROM cte;
JSON 支持

PostgreSQL 提供强大的 JSON 和 JSONB 数据类型:

sql 复制代码
CREATE TABLE orders (
    id SERIAL PRIMARY KEY,
    details JSONB
);

INSERT INTO orders (details) VALUES ('{"product": "Book", "price": 19.99}');
SELECT details->>'product' FROM orders;
全文搜索

支持内置的全文搜索功能:

sql 复制代码
SELECT to_tsvector('The quick brown fox') @@ to_tsquery('quick & fox');

4. 性能优化

  1. 索引

    • 创建索引以提高查询速度:

      sql 复制代码
      CREATE INDEX idx_users_name ON users(name);
    • 支持多种索引类型(B-tree、GIN、GiST、BRIN)。

  2. 分区表

    • 将大表分为多个分区以提高性能:

      sql 复制代码
      CREATE TABLE orders_part (
          id SERIAL,
          order_date DATE NOT NULL
      ) PARTITION BY RANGE (order_date);
  3. 缓存和配置调整

    • 使用 EXPLAIN 分析查询计划:

      sql 复制代码
      EXPLAIN ANALYZE SELECT * FROM users WHERE name = 'Alice';

5. 使用场景

  • Web应用数据库:支持复杂的查询、事务性操作以及扩展性需求。
  • 数据分析:支持 CTE、窗口函数和 JSON 数据处理。
  • 时间序列数据:结合扩展(如 TimescaleDB),支持高效处理时间序列数据。

6. PostgreSQL 的扩展生态

  • PostGIS:用于地理信息系统(GIS)的扩展。
  • TimescaleDB:时间序列数据库扩展。
  • pgAdmin:图形化数据库管理工具。
  • Logical Replication:支持主从复制和逻辑复制。

相关推荐
开开心心就好1 小时前
高效报价软件,简化商铺定价流程
服务器·数据库·安全·面试·职场和发展·电脑·symfony
钢铁男儿2 小时前
PyQt5高级界而控件(容器:装载更多的控件QDockWidget)
数据库·python·qt
阿蒙Amon5 小时前
C# Linq to SQL:数据库编程的解决方案
数据库·c#·linq
互联网搬砖老肖9 小时前
运维打铁: MongoDB 数据库集群搭建与管理
运维·数据库·mongodb
典学长编程9 小时前
数据库Oracle从入门到精通!第四天(并发、锁、视图)
数据库·oracle
积跬步,慕至千里10 小时前
clickhouse数据库表和doris数据库表迁移starrocks数据库时建表注意事项总结
数据库·clickhouse
极限实验室10 小时前
搭建持久化的 INFINI Console 与 Easysearch 容器环境
数据库
白仑色11 小时前
Oracle PL/SQL 编程基础详解(从块结构到游标操作)
数据库·oracle·数据库开发·存储过程·plsql编程
程序猿小D12 小时前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+jsp实现的个人财务管理系统,推荐!
java·数据库·mysql·spring·毕业论文·ssm框架·个人财务管理系统
钢铁男儿13 小时前
C# 接口(什么是接口)
java·数据库·c#