当前位置: 首页 > article >正文

Postgresql常规SQL语句操作

        

目录

一、数据库与对象管理

二、数据操作 (CRUD)

三、查询优化与执行计划分析

四、事务控制

五、数据类型与高级特性应用

六、系统查询与维护

研发中的重要注意事项


        在 PostgreSQL 研发中,以下这些 SQL 应用是极其常见且核心的操作,涵盖了数据库设计、数据操作、查询优化和系统维护的关键方面:

一、数据库与对象管理

  1. 创建/修改表:

    CREATE TABLE employees (id SERIAL PRIMARY KEY,  -- 自增主键name VARCHAR(100) NOT NULL,email VARCHAR(255) UNIQUE,department_id INTEGER REFERENCES departments(id), -- 外键salary NUMERIC(10, 2),hire_date DATE DEFAULT CURRENT_DATE,is_active BOOLEAN DEFAULT true,skills TEXT[] -- 数组类型profile JSONB -- JSONB 类型存储灵活数据
    );-- 添加索引
    CREATE INDEX idx_employees_department ON employees(department_id);
    CREATE INDEX idx_employees_name ON employees(name);
    CREATE INDEX idx_employees_profile_email ON employees USING gin ((profile->>'email')); -- JSONB 字段索引-- 修改表 (添加列、修改列类型、添加约束等)
    ALTER TABLE employees ADD COLUMN phone VARCHAR(20);
    ALTER TABLE employees ALTER COLUMN salary TYPE DECIMAL(12, 2);
    ALTER TABLE employees ADD CONSTRAINT salary_check CHECK (salary > 0);
    
  2. 创建视图:

    CREATE VIEW active_employees AS
    SELECT id, name, email, department_id
    FROM employees
    WHERE is_active = true;
    -- 物化视图 (定期刷新)
    CREATE MATERIALIZED VIEW department_salary_summary AS
    SELECT department_id, AVG(salary) AS avg_salary, SUM(salary) AS total_salary
    FROM employees
    GROUP BY department_id
    WITH DATA;
    REFRESH MATERIALIZED VIEW department_salary_summary; -- 手动刷新
    
  3. 创建函数/存储过程:

    CREATE OR REPLACE FUNCTION get_employee_count(dept_id INTEGER)
    RETURNS INTEGER AS $$
    DECLAREemp_count INTEGER;
    BEGINSELECT COUNT(*) INTO emp_countFROM employeesWHERE department_id = dept_id AND is_active = true;RETURN emp_count;
    END;
    $$ LANGUAGE plpgsql;-- 调用函数
    SELECT get_employee_count(5);
    

二、数据操作 (CRUD)

  1. 插入数据:

    INSERT INTO employees (name, email, department_id, salary)
    VALUES ('Alice Smith', 'alice@example.com', 3, 75000.00),('Bob Johnson', 'bob@example.com', 3, 82000.00);-- 插入来自查询的结果
    INSERT INTO archived_employees (id, name, email, leave_date)
    SELECT id, name, email, CURRENT_DATE
    FROM employees
    WHERE is_active = false;
    
  2. 查询数据:

    • 基础查询:
      SELECT id, name, salary FROM employees WHERE department_id = 3 AND salary > 80000;
      
    • 连接:
      SELECT e.name, d.name AS department_name, e.salary
      FROM employees e
      INNER JOIN departments d ON e.department_id = d.id;
      -- LEFT JOIN, RIGHT JOIN, FULL JOIN 也很常用
      
    • 聚合与分组:
      SELECT department_id, COUNT(*) AS num_employees, AVG(salary) AS avg_salary
      FROM employees
      WHERE is_active = true
      GROUP BY department_id
      HAVING AVG(salary) > 60000;
      
    • 子查询:
      SELECT name, salary
      FROM employees
      WHERE salary > (SELECT AVG(salary) FROM employees);
      
    • 窗口函数:
      SELECT name, department_id, salary,RANK() OVER (PARTITION BY department_id ORDER BY salary DESC) AS dept_salary_rank,salary - LAG(salary) OVER (PARTITION BY department_id ORDER BY hire_date) AS salary_diff
      FROM employees;
      
    • JSONB 查询:
      SELECT name, profile->>'address' AS address -- 提取文本
      FROM employees
      WHERE profile @> '{"skills": ["PostgreSQL"]}'; -- 包含特定键值对
      
  3. 更新数据:

    UPDATE employees
    SET salary = salary * 1.05 -- 涨薪5%
    WHERE department_id = 3 AND performance_rating >= 4;-- 基于子查询更新
    UPDATE employees e
    SET manager_id = (SELECT manager_id FROM departments d WHERE d.id = e.department_id)
    WHERE e.manager_id IS NULL;
    
  4. 删除数据:

    DELETE FROM employees
    WHERE is_active = false AND hire_date < '2020-01-01';-- 使用事务确保操作原子性
    BEGIN;
    -- 先存档再删除
    INSERT INTO deleted_employees_log SELECT *, CURRENT_TIMESTAMP FROM employees WHERE id = 123;
    DELETE FROM employees WHERE id = 123;
    COMMIT;
    

三、查询优化与执行计划分析

  1. EXPLAIN / EXPLAIN ANALYZE

    EXPLAIN ANALYZE
    SELECT * FROM orders
    WHERE customer_id = 456 AND order_date BETWEEN '2023-01-01' AND '2023-12-31'
    ORDER BY total_amount DESC
    LIMIT 10;
    
    • 解读输出,查看是否使用了正确的索引、扫描类型(Seq Scan, Index Scan, Bitmap Heap Scan)、连接策略、排序方式、预估/实际行数、执行时间等。
    • 这是优化慢查询的最重要工具
  2. 强制使用索引 (通常不推荐,优化器通常更聪明):

    SET enable_seqscan = off; -- 临时关闭顺序扫描 (测试用,勿在生产库长期开启)
    -- ... 运行查询 ...
    SET enable_seqscan = on;
    
  3. 创建/优化索引:

    • 组合索引: CREATE INDEX idx_orders_customer_date ON orders(customer_id, order_date);
    • 条件索引: CREATE INDEX idx_active_high_salary ON employees(salary) WHERE is_active = true AND salary > 100000;
    • 表达式索引: CREATE INDEX idx_employee_lower_name ON employees(LOWER(name));
    • 覆盖索引: CREATE INDEX idx_order_summary ON orders(customer_id, order_date) INCLUDE (total_amount); (PG 11+)
    • GIN/GiST 索引: 用于全文搜索(tsvector)、数组、JSONB、几何类型等。

四、事务控制

  1. 显式事务:

    BEGIN;
    -- 一系列操作 (INSERT, UPDATE, DELETE, SELECT ... FOR UPDATE)
    UPDATE accounts SET balance = balance - 100.00 WHERE id = 1;
    UPDATE accounts SET balance = balance + 100.00 WHERE id = 2;
    -- 根据业务逻辑决定提交或回滚
    COMMIT; -- 或 ROLLBACK;
    
  2. 事务隔离级别:

    SET TRANSACTION ISOLATION LEVEL READ COMMITTED; -- 默认级别
    -- 或 REPEATABLE READ, SERIALIZABLE
    BEGIN;
    ... -- 在指定隔离级别下执行事务
    COMMIT;
    
  3. SELECT ... FOR UPDATE / SELECT ... FOR SHARE

    BEGIN;
    SELECT * FROM inventory WHERE product_id = 789 FOR UPDATE; -- 锁定该行,防止其他事务并发修改
    -- 检查库存、扣减库存...
    UPDATE inventory SET stock = stock - 1 WHERE product_id = 789;
    COMMIT;
    

五、数据类型与高级特性应用

  1. JSONB 操作:

    -- 插入
    INSERT INTO products (id, name, attributes)
    VALUES (1, 'T-Shirt', '{"color": "red", "size": ["S", "M", "L"], "material": "cotton"}');-- 查询
    SELECT name, attributes->'size' AS available_sizes
    FROM products
    WHERE attributes @> '{"color": "red"}'; -- 包含 color=red-- 更新
    UPDATE products
    SET attributes = jsonb_set(attributes, '{price}', '19.99') -- 添加/更新 price 键
    WHERE id = 1;UPDATE products
    SET attributes = attributes || '{"discount": 0.1}' -- 合并添加 discount 键
    WHERE id = 1;
    
  2. 数组操作:

    SELECT name FROM employees WHERE 'PostgreSQL' = ANY(skills); -- 包含特定技能
    UPDATE employees SET skills = array_append(skills, 'Docker') WHERE id = 456; -- 添加技能
    SELECT unnest(skills) AS skill, COUNT(*) FROM employees GROUP BY skill; -- 展开数组统计
    
  3. 全文搜索:

    -- 创建 tsvector 列和索引
    ALTER TABLE articles ADD COLUMN search_vector tsvector;
    UPDATE articles SET search_vector = to_tsvector('english', title || ' ' || body);
    CREATE INDEX idx_articles_search ON articles USING gin(search_vector);-- 搜索
    SELECT title, snippet(search_vector, query) AS highlight
    FROM articles, plainto_tsquery('english', 'database performance') query
    WHERE search_vector @@ query
    ORDER BY ts_rank(search_vector, query) DESC;
    

六、系统查询与维护

  1. 查看表/索引信息:

    \d employees -- psql 元命令
    SELECT * FROM pg_tables WHERE schemaname = 'public'; -- 系统表
    SELECT * FROM pg_indexes WHERE tablename = 'employees'; -- 索引信息
    SELECT pg_size_pretty(pg_total_relation_size('employees')); -- 表大小 (含索引)
    
  2. 查看连接/锁:

    SELECT * FROM pg_stat_activity; -- 当前活动连接/查询
    SELECT * FROM pg_locks; -- 当前锁信息
    
  3. 权限管理:

    GRANT SELECT, INSERT, UPDATE ON employees TO developer_role;
    REVOKE DELETE ON employees FROM public;
    

研发中的重要注意事项

  1. 避免 N+1 查询: 在 ORM (如 Hibernate, Django ORM, ActiveRecord) 中尤其要注意。使用 JOIN 或批量查询 (WHERE ... IN (...)) 代替在循环中执行单个查询。
  2. 参数化查询: 永远使用参数化查询或预处理语句来防止 SQL 注入攻击。不要拼接 SQL 字符串。
  3. 理解索引: 不是所有字段都适合加索引。索引有写入开销。理解查询模式,创建合适的索引(类型、字段顺序、条件)。定期分析索引使用情况 (pg_stat_all_indexes)。
  4. 事务边界: 明确事务的开始和结束。保持事务尽可能短小,减少锁竞争。正确处理并发冲突。
  5. 批量操作: 对于大批量插入/更新,使用 COPY 命令、批量 INSERT ... VALUES (...), (...), ... 或 INSERT ... SELECT ...,比循环单条插入高效得多。
  6. 监控与分析: 使用 EXPLAIN ANALYZE 分析慢查询。监控数据库性能指标(连接数、锁、CPU、IO)。使用 pg_stat_statements 扩展找出高频/高消耗 SQL。
  7. 连接池: 在应用层(如 HikariCP, pgBouncer)使用连接池管理数据库连接,避免频繁建立/断开连接的开销。
  8. 模式迁移: 使用成熟的迁移工具(如 Flyway, Liquibase, Alembic, Django Migrations)管理数据库模式变更,确保变更可追溯、可重复、可在不同环境一致执行。

        掌握这些常规 SQL 应用并结合 PostgreSQL 的强大特性(如 JSONB、数组、GIN/GiST 索引、窗口函数、CTE、强大的 PL/pgSQL),能够高效、安全地进行应用研发,构建高性能、可扩展的后端系统。


     这篇博客到这里就接近尾声了,希望我的分享能给您带来一些启发和帮助,别忘了点赞、收藏。您的每一次互动、鼓励是我持续创作的动力!期待与您再次相遇,共同探索更广阔的世界!

相关文章:

Postgresql常规SQL语句操作

目录 一、数据库与对象管理 二、数据操作 (CRUD) 三、查询优化与执行计划分析 四、事务控制 五、数据类型与高级特性应用 六、系统查询与维护 研发中的重要注意事项 在 PostgreSQL 研发中&#xff0c;以下这些 SQL 应用是极其常见且核心的操作&#xff0c;涵盖了数据库设…...

智能合约安全漏洞解析:从 Reentrancy 到 Integer Overflow

目录 &#x1f300; Reentrancy&#xff08;重入攻击&#xff09; 原理解析 典型案例&#xff1a;The DAO 攻击事件 漏洞示例 防范措施 &#x1f522; Integer Overflow&#xff08;整数溢出&#xff09; 原理解析 漏洞示例 防范措施 &#x1f6e1;️ 总结与建议 随着…...

英国2025年战略防御评估报告:网络与电磁域成现代战争核心

英国 2025 年战略防御评估 (SDR) 详细制定了一项计划&#xff0c;通过加强使用网络、人工智能和数字战争来整合其军事防御和进攻能力。 与美国一样&#xff0c;英国也被认为&#xff08;尽管未被公开证实&#xff09;会开展进攻性网络行动&#xff0c;甚至针对盟友。斯诺登泄露…...

基于QPSK调制解调+Polar编译码(SCL译码)的matlab性能仿真,并对比BPSK

目录 1.引言 2.算法仿真效果演示 3.数据集格式或算法参数简介 4.MATLAB核心程序 5.算法涉及理论知识概要 6.参考文献 7.完整算法代码文件获得 1.引言 Polar码由土耳其教授Erdal Arikan于2008年提出&#xff0c;是第一种被严格证明可以达到香农极限的构造性编码方法。其核…...

go语言学习 第5章:函数

第5章&#xff1a;函数 函数是编程中不可或缺的一部分&#xff0c;它封装了一段可重复使用的代码&#xff0c;用于执行特定的任务。在Go语言中&#xff0c;函数同样扮演着重要的角色。本章将详细介绍Go语言中函数的定义、调用、参数传递、返回值处理以及一些高级特性&#xff…...

Qt Quick快速入门笔记

Qt Quick快速入门笔记 基本的程序结构int main(int argc, char *argv[]) { #if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling); #endifQGuiApplication app(argc, argv);QQmlApplicationEngine engine;const QUrl ur…...

《波段操盘实战技法》速读笔记

文章目录 书籍信息概览实战八法波段见顶信号中长线大顶形态投资理念 书籍信息 书名&#xff1a;《波段操盘实战技法》 作者&#xff1a;何瑞东 概览 实战八法 投资理念和投资理论概述&#xff1a;波段操作的核心是通过捕捉股价波动中的趋势性机会&#xff0c;结合技术分析与…...

Glide NoResultEncoderAvailableException异常解决

首先将解决方法提出来&#xff1a;缓存策略DiskCacheStrategy.DATA。 使用Glide加载图片&#xff0c;版本是4.15.0&#xff0c;有天发现无法显示gif图片&#xff0c;原始代码如下&#xff1a; Glide.with(context).load(本地资源路径).diskCacheStrategy(DiskCacheStrategy.A…...

工厂模式与多态结合

工厂模式与多态的结合是平台化项目中实现灵活架构的核心技术之一。这种组合能够创建可扩展、易维护的系统架构。 多态(Polymorphism)指同一操作作用于不同的对象&#xff0c;可以有不同的解释&#xff0c;产生不同的执行结果。 例子1&#xff1a; public abstract class Pay…...

无人机巡检智能边缘计算终端技术方案‌‌——基于EFISH-SCB-RK3588工控机/SAIL-RK3588核心板的国产化替代方案‌

一、方案核心价值‌ ‌实时AI处理‌&#xff1a;6TOPS NPU实现无人机影像的实时缺陷检测&#xff08;延迟&#xff1c;50ms&#xff09;‌全国产化‌&#xff1a;芯片、操作系统、算法工具链100%自主可控‌极端环境适配‌&#xff1a;-40℃~85℃稳定运行&#xff0c;IP65防护等…...

相机--相机成像原理和基础概念

教程 成像原理 基础概念 焦距&#xff08;物理焦距&#xff09; 镜头的光学中心到感光元件之间的距离&#xff0c;用f表示&#xff0c;单位&#xff1a;mm&#xff1b;。 像素焦距 相机内参矩阵中的 fx​ 和 fy​ 是将物理焦距转换到像素坐标系的产物&#xff0c;可能不同。…...

2025-0604学习记录17——文献阅读与分享(2)

最近不是失踪了&#xff01;也不是弃坑了...这不是马上要毕业了嘛&#xff01;所以最近在忙毕业论文答辩、毕业去向填报、户档去向填报等等&#xff0c;事情太多了&#xff0c;没顾得上博客。现在这些事基本上都解决完了&#xff0c;也有时间静下心来写写文字了~ 想要写的内容…...

图解浏览器多进程渲染:从DNS到GPU合成的完整旅程

目录 浅谈浏览器进程 浏览器进程架构的演化 进程和线程关系图示 进程&#xff08;Process&#xff09; 线程&#xff08;Thread&#xff09; 协程&#xff08;Coroutine&#xff09; 进程&线程&协程核心对比 单进程和多进程浏览器 单进程浏览器​编辑 单进程…...

【计算机网络】第3章:传输层—TCP 拥塞控制

目录 一、PPT 二、总结 TCP 拥塞控制详解 ⭐ 核心机制与算法 1. 慢启动&#xff08;Slow Start&#xff09; 2. 拥塞避免&#xff08;Congestion Avoidance&#xff09; 3. 快速重传&#xff08;Fast Retransmit&#xff09; 4. 快速恢复&#xff08;Fast Recovery&…...

idea不识别lombok---实体类报没有getter方法

介绍 本篇文章&#xff0c;主要讲idea引入lombok后&#xff0c;在实体类中加注解Data&#xff0c;在项目启动的时候&#xff0c;编译不通过&#xff0c;报错xxx.java没有getXxxx&#xff08;&#xff09;方法。 原因有以下几种 1. idea没有开启lombok插件 2. 使用idea-2023…...

【Hive入门】

之前实习写的笔记&#xff0c;上传留个备份。 1. 使用docker-compose快速搭建Hive集群 使用docker快速配置Hive环境 拉取镜像 2. Hive数据类型 隐式转换&#xff1a;窄的可以向宽的转换显式转换&#xff1a;cast 3. Hive读写文件 SerDe:序列化&#xff08;对象转为字节码…...

亚马逊站内信规则2025年重大更新:避坑指南与合规策略

亚马逊近期对Buyer-Seller Messaging&#xff08;买家-卖家站内信&#xff09;规则进行了显著收紧&#xff0c;明确将一些曾经的“灰色操作”列为违规。违规操作轻则收到警告&#xff0c;重则导致账户暂停或绩效受限。本文为您全面解析本次规则更新的核心要点、背后逻辑&#x…...

01 - AI 时代的操作系统课 [2025 南京大学操作系统原理]

01 - AI 时代的操作系统课 [2025 南京大学操作系统原理] [00:00:00]-[D:\movie\南京大学操作系统\01-AI时代的操作系统课[2025南京大学操作系统原理].mp4] 大家好&#xff01;我是姜艳艳&#xff0c;来自南京大学计算机软件研究所。今天我们开启《操作系统原理》的第一课&…...

数组1 day7

六&#xff1a;数组 一&#xff1a;数据类型 1.int a[10] //想要知道一个标识符对应的数据类型&#xff0c;去掉标识符&#xff0c;剩下就是它对应的数据类型 ​ //eg&#xff1a;a所谓代表的类型&#xff0c;就是int[10]这种类型&#xff08;是一个数组&#xff0c;包含10个…...

SAP学习笔记 - 开发15 - 前端Fiori开发 Boostrap,Controls,MVC(Model,View,Controller),Modules

上一章讲了Fiori开发的准备&#xff0c;以及宇宙至简之HelloWorld。 SAP学习笔记 - 开发14 - 前端Fiori开发 HelloWorld-CSDN博客 本章继续学习 Fiori 开发的知识&#xff1a; Bootstrap&#xff0c;Controls&#xff0c;MVC(Model&#xff0c;View&#xff0c;Controller&a…...

Redis中的过期策略与内存淘汰策略

因为Redis是纯内存操作&#xff0c;所以在Redis中创建的键一般都会带有过期时间&#xff0c;以此来保证内存中存储数据的时效性。这篇文章我们就来讲解一下Redis中的过期策略与内存淘汰策略。 如何设置Redis中键的过期时间&#xff1f; Redis提供了4个命令来设置键的过期时间&…...

基于SDN环境下的DDoS异常攻击的检测与缓解

参考以下两篇博客&#xff0c;最后成功&#xff1a; 基于SDN的DDoS攻击检测和防御方法_基于sdn的ddos攻击检测与防御-CSDN博客 利用mininet模拟SDN架构并进行DDoS攻击与防御模拟&#xff08;Ryumininetsflowpostman&#xff09;_mininet模拟dos攻击-CSDN博客 需求 H2 模拟f…...

HarmonyOS 实战:给笔记应用加防截图水印

最近在做笔记类应用时&#xff0c;遇到一个头疼的需求&#xff1a;防止用户内容被非法截图传播。思来想去&#xff0c;加水印是个直接有效的方案。研究了 HarmonyOS 的开发文档后&#xff0c;发现用 Canvas 配合布局组件能轻松实现动态水印效果。今天就来聊聊如何给笔记页面加上…...

如何轻松地将文件从 PC 传输到 iPhone?

传统上&#xff0c;您可以使用 iTunes 将文件从 PC 传输到 iPhone&#xff0c;但现在&#xff0c;使用 iTunes 已不再是唯一的选择。现在有多种不同且有效的方法可以帮助您传输文件。在今天的指南中&#xff0c;您可以找到 8 种使用或不使用 iTunes 传输文件的方法&#xff0c;…...

前端面试二之运算符与表达式

目录 1.JavaScript 中的 和 运算符 2.|| (逻辑或) 运算符 与 ES6 默认参数的区别 与 ?? (空值合并运算符) 的区别 3.?.&#xff08;可选链&#xff09;运算符 (1). 安全访问深层嵌套属性 (2). 安全调用可能不存在的函数 (3). 安全访问数组元素 4.展开运算符 (..…...

【运维实战】使用Nvm配置多Node.js环境!

背景 新项目 使用Node.js-v16.17.1旧项目 使用Node.js- v14.18.0 【且依赖于node-saas模块&#xff0c;根据 node-sass 的官方文档&#xff0c;目前最新版本的 node-sass&#xff08;即 v5.0.0&#xff09;支持的 Node.js 版本范围是 Node.js 10.x、Node.js 12.x、Node.js 14.…...

Bresenham算法

一 Bresenham 绘直线 使用 Bresenham 算法&#xff0c;可以在显示器上绘制一直线段。该算法主要思想如下&#xff1a; 1 给出直线段上两个端点 &#xff0c;根据端点求出直线在X,Y方向上变化速率 &#xff1b; 2 当 时&#xff0c;X 方向上变化速率快于 Y 方向上变化速率&am…...

【从GEO数据库批量下载数据】

从GEO数据库批量下载数据 1&#xff1a;进入GEO DataSets拿到所需要下载的数据的srr.list&#xff0c;上传到linux&#xff0c; 就可以使用prefetch这个函数来下载 2&#xff1a;操作步骤如下&#xff1a; conda 安装sra-tools conda create -n sra-env -c bioconda -c co…...

day 44

使用DenseNet预训练模型对cifar10数据集进行训练 import torch import torch.nn as nn import torch.optim as optim from torchvision import datasets, transforms, models from torch.utils.data import DataLoader import matplotlib.pyplot as plt import os# 设置中文字体…...

鸿蒙OSUniApp开发跨平台AR扫描识别应用:HarmonyOS实践指南#三方框架 #Uniapp

UniApp开发跨平台AR扫描识别应用&#xff1a;HarmonyOS实践指南 前言 随着增强现实&#xff08;AR&#xff09;技术在移动应用中的广泛应用&#xff0c;越来越多的开发者需要在跨平台应用中实现AR功能。本文将深入探讨如何使用UniApp框架开发一个高性能的AR扫描识别应用&…...