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:支持主从复制和逻辑复制。

相关推荐
夜泉_ly10 分钟前
MySQL -安装与初识
数据库·mysql
qq_529835351 小时前
对计算机中缓存的理解和使用Redis作为缓存
数据库·redis·缓存
月光水岸New4 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
狄加山6754 小时前
数据库基础1
数据库
我爱松子鱼4 小时前
mysql之规则优化器RBO
数据库·mysql
chengooooooo4 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
Rverdoser5 小时前
【SQL】多表查询案例
数据库·sql
Galeoto5 小时前
how to export a table in sqlite, and import into another
数据库·sqlite
人间打气筒(Ada)6 小时前
MySQL主从架构
服务器·数据库·mysql
leegong231116 小时前
学习PostgreSQL专家认证
数据库·学习·postgresql