【PostgreSQL】【第3章】PostgreSQL的对象操作

1. 表约束

1.1 常见约束类型
  • 主键约束 (PRIMARY KEY)
    用于唯一标识表中的每条记录。语法示例:

    sql 复制代码
    CREATE TABLE test (
      ID BIGSERIAL PRIMARY KEY,
      name VARCHAR(64) NOT NULL
    );
  • 非空约束 (NOT NULL)
    确保字段值不为空:

    sql 复制代码
    CREATE TABLE test (
      name VARCHAR(64) NOT NULL
    );
  • 唯一约束 (UNIQUE)
    确保字段值唯一:

    sql 复制代码
    CREATE TABLE test (
      id_card VARCHAR(18) UNIQUE
    );
  • 检查约束 (CHECK)
    自定义条件验证数据:

    sql 复制代码
    CREATE TABLE product (
      price NUMERIC CHECK(price > 0),
      discount_price NUMERIC CHECK(discount_price <= price)
    );
1.2 外键约束的争议
  • 外键的缺点
    可能导致级联操作风险(如误删数据)和维护复杂度高,不推荐使用

2. 表默认值

2.1 默认值设置
  • 常用场景:自动填充创建时间、更新时间等字段:

    sql 复制代码
    CREATE TABLE user (
      create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP
    );

3. 触发器

3.1 触发器实现级联删除
  • 步骤
    1. 创建学生表和分数表:

      sql 复制代码
      CREATE TABLE student (ID INT, name VARCHAR(64));
      CREATE TABLE score (student_id INT, math NUMERIC);
    2. 编写触发器函数:

      sql 复制代码
      CREATE FUNCTION delete_score() RETURNS TRIGGER AS $$
      BEGIN
        DELETE FROM score WHERE student_id = OLD.ID;
        RETURN OLD;
      END;
      $$ LANGUAGE plpgsql;
    3. 绑定触发器:

      sql 复制代码
      CREATE TRIGGER trigger_delete_student 
      AFTER DELETE ON student 
      FOR EACH ROW EXECUTE FUNCTION delete_score();

4. 表空间管理

4.1 表空间的作用
  • 核心功能:指定表的物理存储路径。

  • 创建表空间

    sql 复制代码
    CREATE TABLESPACE ts_test LOCATION '/path/to/directory';
  • 查询表存储路径

    sql 复制代码
    SELECT pg_relation_filepath('student');
4.2 表空间存储问题
  • 软链接机制 :默认路径和指定路径会同时存在符号链接,避免重复存储。

5. 视图

5.1 视图的创建与限制
  • 简单视图 (单表查询):

    sql 复制代码
    CREATE VIEW student_view AS 
    SELECT ID, name FROM student;
  • 复杂视图 (多表关联):

    sql 复制代码
    CREATE VIEW student_score AS
    SELECT s.name, sc.math 
    FROM student s 
    JOIN score sc ON s.ID = sc.student_id;
  • 限制 :复杂视图不支持写操作


6. 索引应用

6.1 索引类型与性能对比
  • B-Tree 索引 (默认):

    sql 复制代码
    CREATE INDEX idx_name ON test (name);
  • GIN 索引 (适用于数组字段):

    sql 复制代码
    CREATE INDEX idx_phones ON user USING GIN (phones);
6.2 性能测试
  • 无索引查询 :全表扫描 (Seq Scan),耗时约 0.5 秒。
  • 有索引查询 :索引扫描 (Index Scan),耗时约 0.05 秒。

7. 物化视图

7.1 物化视图特性
  • 与普通视图的区别持久化存储数据,查询效率更高。

  • 创建示例

    sql 复制代码
    CREATE MATERIALIZED VIEW mv_product AS 
    SELECT ID, name FROM product;
7.2 数据同步方式
  • 全量更新

    sql 复制代码
    REFRESH MATERIALIZED VIEW mv_product;
  • 增量更新 (需唯一索引):

    sql 复制代码
    CREATE UNIQUE INDEX idx_mv_id ON mv_product (ID);
    REFRESH MATERIALIZED VIEW CONCURRENTLY mv_product;
7.3 更新机制
  • 版本控制 :通过 xminxmax 字段追踪数据版本变化。

关键术语

  • 约束 (Constraints):用于保证数据完整性的规则。
  • 触发器 (Trigger):事件驱动的存储过程。
  • 物化视图 (Materialized View):缓存复杂查询结果的物理表。

操作提示

  • 索引优化需根据查询模式选择合适类型。
  • 物化视图的更新频率需平衡性能与数据实时性需求。
相关推荐
m0_7364393019 小时前
如何防止SQL非法金额输入_利用触发器实现精确度校准
jvm·数据库·python
消失的旧时光-194319 小时前
线程池解决了什么?为什么还不够?(从线程到协程 · 第2篇)
java·大数据·数据库
秋919 小时前
sqlyog连接mysql8.4.9时报Plugin caching_sha2_password could not be loaded错误的解决方法
数据库
2301_8159019719 小时前
HTML函数在4K显示器上显示异常吗_高分辨率硬件适配问题【详解】
jvm·数据库·python
运气好好的20 小时前
CSS如何实现响应式内边距自适应_利用vw单位动态调整
jvm·数据库·python
大江东去浪淘尽千古风流人物20 小时前
【UV-SLAM】eLSD/LBD 数据维度 UV-SLAM吸收借鉴
数据库·线性代数·oracle·矩阵·uv·augmented reality
小妖同学学AI20 小时前
抛弃传统数据库!Qdrant用Rust重写AI记忆,大模型知识库迎来性能革命!
数据库·人工智能·rust
m0_7411733320 小时前
如何实现SQL复杂计算触发器原子性_利用触发器事务控制
jvm·数据库·python
秋920 小时前
一键安装mysql8.0.46(附脚本)
数据库
abc123456sdggfd20 小时前
C#怎么使用gRPC双向流_C#如何实现高效RPC调用【进阶】
jvm·数据库·python