news 2026/4/19 21:31:17

PostgreSQL基础知识——DDL深度解析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
PostgreSQL基础知识——DDL深度解析

E)

表是关系型数据库中最基本的对象,PostgreSQL支持丰富的数据类型与约束机制。

常用数据类型示例:

类型分类常用数据类型存储范围/特性示例
数值型INT/BIGINT4/8字节整数100,500
数值型DECIMAL(p,s)高精度十进制数DECIMAL(10,2)→1234.56
字符型VARCHAR(n)可变长字符串'数据分析'
字符型TEXT无长度限制字符串长文本内容
日期时间DATE年月日'20231231'
日期时间TIMESTAMPWITHTIMEZONE带时区的时间戳'2024010110:00:00+08'
布尔型BOOLEAN真/假TRUE/FALSE
二进制BYTEA二进制数据\\xDEADBEEF

创建表示例:

```sql

部门表

CREATETABLEdepartments(

dept_idINTEGERPRIMARYKEY,

dept_nameVARCHAR(50)

);

员工信息表(含多种约束)

CREATETABLEemployees(

emp_idSERIALPRIMARYKEY,自增主键

emp_nameVARCHAR(50)NOTNULL,非空约束

emailVARCHAR(100)UNIQUE,唯一约束

hire_dateDATEDEFAULTCURRENT_DATE,默认值约束

salaryNUMERIC(10,2)CHECK(salary0),检查约束

department_idINTEGERREFERENCESdepartments(dept_id)外键约束

);

```

约束类型对比:

约束类型关键字作用性能影响
主键PRIMARYKEY唯一标识记录读优化,写轻微影响
唯一UNIQUE确保字段值唯一类似主键,允许NULL
非空NOTNULL禁止字段为空无索引性能影响
检查CHECK自定义逻辑约束每次写入时触发检查
外键REFERENCES建立表间关联级联操作需额外开销

修改表结构(ALTERTABLE)

`ALTERTABLE`功能丰富,用于表创建后修改其定义。

```sql

添加字段(带默认值)

ALTERTABLEemployeesADDCOLUMNphoneVARCHAR(20)DEFAULT'未提供';

修改数据类型(需重建表)

ALTERTABLEemployeesALTERCOLUMNsalaryTYPENUMERIC(12,2);

删除字段(生产环境慎用)

ALTERTABLEemployeesDROPCOLUMNfax;

添加外键(延迟约束检查)

ALTERTABLEemployees

ADDCONSTRAINTfk_dept

FOREIGNKEY(department_id)REFERENCESdepartments(dept_id)

DEFERRABLEINITIALLYDEFERRED;

``

关键选项解析:

`CASCADE`:自动删除依赖该列的对象(如视图、外键)。

`RESTRICT`(默认):存在依赖对象时拒绝删除。

`USING`子句:指定从旧类型到新类型的转换规则。

删除表(DROPTABLE)

```sql

级联删除依赖对象

DROPTABLEIFEXISTSemployeesCASCADE;

仅删除表结构,保留数据(PostgreSQL12+)

TRUNCATETABLEemployees;

```

重要提示:`TRUNCATE`比`DELETEFROM`效率高10–100倍,适合清空大表。

2.3索引创建与管理

索引是提升查询性能的关键机制,PostgreSQL支持多种索引类型。

基本索引创建:

```sql

创建Btree索引(默认)

CREATEINDEXidx_employee_nameONemployees(emp_name);

创建唯一索引

CREATEUNIQUEINDEXidx_unique_emailONemployees(email);

创建多列复合索引

CREATEINDEXidx_dept_salaryONemployees(department_id,salaryDESC);

```

并发创建索引:

适用于在线业务,避免阻塞其他会话的DML操作。

```sql

CREATEINDEXCONCURRENTLYidx_employee_nameONemployees(emp_name);

```

部分索引(PartialIndex):

仅对满足条件的行创建索引,减少索引大小。

```sql

CREATEINDEXidx_active_employeesONemployees(department_id)WHEREactive=true;

```

表达式索引:

在表达式上创建索引。

```sql

CREATEINDEXidx_lower_nameONemployees(LOWER(emp_name));

```

2.4视图创建与管理

视图是基于一个或多个表的查询结果集定义的虚拟表,不存储实际数据。

基本视图创建:

```sql

基于多表连接创建视图

CREATEVIEWemployee_detailsAS

SELECTe.emp_id,e.emp_name,e.salary,d.dept_name

FROMemployeese

JOINdepartmentsdONe.department_id=d.dept_id;

查询视图

SELECTFROMemployee_detailsWHEREsalary5000;

```

可更新视图与检查选项:

```sql

创建带检查选项的视图

CREATEVIEWhigh_paid_employeesAS

SELECTFROMemployeesWHEREsalary10000

WITHCHECKOPTION;

以下插入会失败(5000<10000)

INSERTINTOhigh_paid_employees(emp_name,salary)VALUES('John',5000);

```

物化视图(MaterializedView):

将查询结果实际存储,需手动刷新。

```sql

创建物化视图

CREATEMATERIALIZEDVIEWmonthly_sales_summaryAS

SELECTdate_trunc('month',sale_date)ASmonth,

product_id,

SUM(amount)AStotal_sales

FROMsales

GROUPBYdate_trunc('month',sale_date),product_id;

刷新物化视图

REFRESHMATERIALIZEDVIEWmonthly_sales_summary;

```

2.5外键与参照完整性深度解析

外键是实现参照完整性(ReferentialIntegrity)的核心机制。

外键约束创建:

```sql

在创建表时定义外键

CREATETABLEorders(

order_idSERIALPRIMARYKEY,

product_idINTEGERREFERENCESproducts(product_id)ONDELETECASCADE,

quantityINTEGER,

order_dateDATEDEFAULTCURRENT_DATE

);

通过ALTERTABLE添加外键

ALTERTABLEorders

ADDCONSTRAINTfk_product

FOREIGNKEY(product_id)REFERENCESproducts(product_id);

```

引用动作(ReferentialActions):

定义父表记录更新或删除时子表记录的响应方式。

动作描述示例
NOACTION/RESTRICT禁止操作(默认)父表记录有引用时禁止删除
CASCADE级联删除或更新删除父表记录时同时删除子表相关记录
SETNULL将子表中外键列设置为NULL删除父表记录时将子表外键设为NULL
SETDEFAULT将子表中外键列设置为默认值删除父表记录时将子表外键设为默认值

示例:

```sql

CREATETABLEorder_items(

item_idSERIALPRIMARYKEY,

order_idINTEGERREFERENCESorders(order_id)ONDELETECASCADE,

product_idINTEGERREFERENCESproducts(product_id)ONDELETESETNULL,

quantityINTEGER

);

```

外键性能优化:

若PostgreSQL版本未自动建立外键索引,需手动创建以避免影响更新或删除性能。

```sql

为外键列创建索引

CREATEINDEXidx_order_items_order_idONorder_items(order_id);

CREATEINDEXidx_order_items_product_idONorder_items(product_id);

```

2.6对象重命名(RENAME)

重命名操作用于修改数据库对象的名称。

```sql

重命名表

ALTERTABLEemployeesRENAMETOstaff;

重命名列

ALTERTABLEemployeesRENAMECOLUMNemp_nameTOfull_name

重命名索引

ALTERINDEXidx_old_nameRENAMETOidx_new_name;

重命名视图

ALTERVIEWold_view_nameRENAMETOnew_view_name;

重命名序列

ALTERSEQUENCEold_sequence_nameRENAMETOnew_sequence_name;

```

注意事项:

重命名操作立即生效,无法回滚。

重命名后,所有引用该对象的地方均需更新。

建议在低峰期执行重命名操作。

2.7注释管理(COMMENT)

注释是数据库文档化的重要组成部分。

基本语法:

```sql

COMMENTON{对象类型}对象名称IS'注释文本'|NULL;

```

为各类对象添加注释:

```sql

为表添加注释

COMMENTONTABLEemployeesIS'员工信息表,存储公司所有员工的基本信息';

为列添加注释

COMMENTONCOLUMNemployees.salaryIS'员工月薪,单位为人民币元,税前金额';

为索引添加注释

COMMENTONINDEXidx_employee_nameIS'员工姓名索引,用于加速按姓名查询';

为视图添加注释

COMMENTONVIEWemployee_detailsIS'员工详细信息视图,包含员工及其部门信息';

为函数添加注释

COMMENTONFUNCTIONcalculate_bonus(decimal,integer)IS'计算员工年终奖金,参数1:基本工资,参数2:绩效评分';

```

修改与删除注释:

```sql

修改注释(直接覆盖)

COMMENTONTABLEemployeesIS'员工信息主表,包含员工基本信息、薪资和部门信息';

删除注释(设置为NULL)

COMMENTONTABLEemployeesISNULL;

```

查看注释:

```sql

使用系统函数查看

SELECTobj_description('employees'::regclass,'pg_class');

SELECTcol_description('employees'::regclass,列序号);

```

注释最佳实践:

为所有重要对象(表、列、索引、视图、函数等)添加注释。

保持注释简洁明了,统一团队内部注释风格。

在注释中说明重要的业务规则与约束。

记录重要的表结构变更原因与时间

权限与安全提示:

大多数对象只有所有者可设置或修改注释。

注释无安全机制,所有连接用户均可查看,请勿存放敏感信息。

2.8NULL值的处理与最佳实践

NULL表示“未知”或“不存在”的值,不同于空字符串或零。

NULL比较与计算:

```sql

正确:使用ISNULL判断

SELECTFROMemployeesWHEREsalaryISNULL;

错误:与NULL的比较结果总是NULL(视为FALSE)

SELECTFROMemployeesWHEREsalary=NULL;不会返回任何行

包含NULL的计算结果通常也是NULL

SELECT10+NULL;返回NULL

SELECT'Hello'||NULL;返回NULL

```

NULL与约束:

`NOTNULL`约束:确保列不允许NULL值。

`UNIQUE`约束:PostgreSQL视多个NULL值为互不相同(允许存在多个NULL)。

外键中的NULL:外键列允许为NULL,表示该记录未关联到父表。

处理NULL的函数:

```sql

COALESCE:返回第一个非NULL值

SELECTCOALESCE(salary,0)ASeffective_salaryFROMemployees;

NULLIF:如果两个表达式相等则返回NULL

SELECTNULLIF(salary,0)FROMemployees;若salary为0则返回NULL

ISDISTINCTFROM:比较时考虑NULL

SELECTFROMt1WHEREaISDISTINCTFROMb;

```

来源:小程序app开发|ui设计|软件外包|IT技术服务公司-木风未来科技-成都木风未来科技有限公司

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/19 0:27:43

2026运维监控系统选型全景:全栈智能可观测产品对比与决策指南

数字化转型的纵深推进与云原生架构的广泛普及&#xff0c;让企业IT环境迈入混合云、微服务与容器化深度融合的复杂阶段。运维监控作为保障IT系统稳定运行、支撑业务持续增长的“神经中枢”&#xff0c;其价值已从传统的故障事后响应&#xff0c;升级为事前预测、事中精准处置与…

作者头像 李华
网站建设 2026/4/17 21:47:32

历时数十年的漏洞与新堆损坏问题,Linux系统关键glibc漏洞曝光

作为大多数Linux系统核心基础的GNU C库&#xff08;glibc&#xff09;维护团队披露了两个安全漏洞的详细信息&#xff0c;问题严重性从高危堆损坏到信息泄露不等。这些漏洞影响范围广泛&#xff0c;其中一个漏洞可追溯至glibc 2.0版本。高危漏洞的技术特性虽然这两个漏洞都可能…

作者头像 李华
网站建设 2026/4/18 0:14:30

《P2455 [SDOI2006] 线性方程组》

题目描述 已知 n 元线性一次方程组。 ⎩⎨⎧​a1,1​x1​a1,2​x2​⋯a1,n​xn​b1​a2,1​x1​a2,2​x2​⋯a2,n​xn​b2​⋯an,1​x1​an,2​x2​⋯an,n​xn​bn​​ 请根据输入的数据&#xff0c;编程输出方程组的解的情况。 输入格式 第一行输入未知数的个数 n。 接下…

作者头像 李华
网站建设 2026/4/19 1:35:48

会计职称考试照片大小标准是多少?快速压缩方法分享

报考会计职称时&#xff0c;不少人卡在照片上传这一步&#xff1a;要么提示照片太大无法提交&#xff0c;要么格式不符合要求&#xff0c;找压缩工具又怕下载的软件有广告、操作复杂。会计职称考试报名照片有明确规范&#xff1a;背景需为白色&#xff0c;采用近期 1 寸免冠证件…

作者头像 李华
网站建设 2026/4/18 16:50:08

GIF动画在线制作工具怎么选?GIF中文网免费动图制作全攻略

做自媒体配图、电商主图或课件动图时&#xff0c;总遇到GIF制作复杂、转换后格式不兼容&#xff0c;甚至动图太大无法上传的问题&#xff0c;浪费大量时间还没效果。今天给大家推荐5分钟快速上手的在线GIF工具&#xff08;https://www.gif.cn/&#xff09; ——GIF 中文网&…

作者头像 李华
网站建设 2026/4/19 6:31:21

我常用的一个电商数据采集软件,低代码爬虫

最近DeepSeek大火&#xff0c;对话质量之高一度超过ChatGPT、Claude等主流海外模型。你知道什么决定了大模型训练结果的好坏吗?除了算法外&#xff0c;训练数据的质和量起着决定性作用&#xff0c;而很多AI公司用到的训练数据就是利用爬虫技术从全网抓取的&#xff0c;这也是O…

作者头像 李华