深入理解PostgreSql域类型(Domain),灵活定义数据约束,让表结构设计更加严谨

news/2024/8/26 15:36:37 标签: postgresql, 数据库

在这里插入图片描述

在PostgreSQL中,域(Domain)是一种用户定义的数据类型,它基于系统内已存在的数据类型,并可以附加约束条件。使用域可以增强数据的完整性和一致性,因为它允许开发者对特定列设定更为具体的规则,比如指定默认值、限制取值范围或格式。这有助于确保数据库表中的数据符合业务逻辑要求,减少错误和不一致的数据输入,从而提高数据质量。简而言之,域提供了一种封装数据类型及其约束的有效方式,使得这些规则可以在多个表中重用,简化了数据库设计和维护工作。

对Domain的理解

Postgresql中的Domain是指在定义表列时,可以定义一组具有相同性质的值,根据Domain定义的表列只能用其定义的值,将该列所需要的值集合为一个统一的值域,可以用于限制值的类型。

使用Domain的主要优点是它可以为每个列设置不同类型的限制,为每个列都创建相同的限制,同时可用于多个表的多个列,以提高可重用性,并减少编码时间。

使用Domain的缺点是它有一定的灵活性,但在建立Domain之前用户必须清楚地定义每个Domain,因此有可能造成一定程度上的冗余。

Domain的功能

数据类型封装

Domain可以将一个或多个现有的数据类型封装成一个新的数据类型。这样可以提高代码的可读性和可维护性,同时也可以减少错误的发生。

数据约束

Domain可以定义一组约束条件,用于限制数据的取值范围。例如,可以定义一个Domain来限制某个列的取值只能是特定的枚举值,或者限制某个列的取值范围在一定的数值范围内。

数据验证

Domain可以定义一组验证规则,用于验证数据的有效性。例如,可以定义一个Domain来验证某个列的值是否符合特定的正则表达式,或者验证某个列的值是否满足一定的业务逻辑。

数据转换

Domain可以定义一组转换规则,用于在存储和检索数据时进行数据转换。例如,可以定义一个Domain来将某个列的值从一种数据类型转换为另一种数据类型,或者将某个列的值进行格式化。

Domain的常用操作

创建Domain
create domain s_string100 as VARCHAR(100);
删除Domain
drop domain if exists s_string100 ;
查看创建的Domain
SELECT oid, typname FROM pg_type WHERE typtype = 'd';

Domain的使用示例

创建邮箱校验Domain
CREATE DOMAIN email_domain AS varchar(255)
CHECK (VALUE ~ '^[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,}$');
在表中关联使用Domain
CREATE TABLE users (
    id serial PRIMARY KEY,
    name varchar(100) NOT NULL,
    email email_domain UNIQUE
);

小贴士: Domain不仅可以简化字段类型声明,还能在多个表中统一应用相同的约束,便于维护和确保数据质量


http://www.niftyadmin.cn/n/5559012.html

相关文章

linux中 crontab 定时器用法

*/10 * * * * python3 /home/code/haha2.py Crontab 当然,以下是一个简短的博客,介绍了 Cron 和 Crontab 的用法: --- # 简介:使用 Cron 和 Crontab 在 Linux 中进行定时任务调度 在 Linux 系统中,Cron 是一个用于…

MySQL-事务、日志

事务 特性 原子性 是指事务开始后,必须成功执行完所有的操作才会结束,否则会回滚到事务刚开始前。 拿转账来说,一个成功的 A向B转账100元的过程 会涉及如下过程: A:从数据库读取A的余额;A的余额-100&am…

LabVIEW设备检修信息管理系统

开发了基于LabVIEW设计平台开发的设备检修信息管理系统。该系统应用于各种设备的检修基地,通过与基地管理信息系统的连接和数据交换,实现了本地检修工位数据的远程自动化管理,提高了设备的检修效率和安全性。 项目背景 现代设备运维过程中信…

Calibration相机内参数标定

1.环境依赖 本算法采用张正友相机标定法进行实现,内部对其进行了封装。 环境依赖为 ubuntu20.04 opencv4.2.0 yaml-cpp yaml-cpp安装方式: (1)git clone https://github.com/jbeder/yaml-cpp.git #将yaml-cpp下载至本地 &a…

代码随想三刷图论篇2

代码随想三刷图论篇2 104. 建造最大岛屿题目代码 110. 字符串接龙题目代码 105. 有向图的完全可达性题目代码 106. 岛屿的周长题目代码 104. 建造最大岛屿 题目 链接 代码 import java.util.*; class Main{public static void main(String[] args){Scanner sc new Scanner…

无缝集成的艺术:在Conda中启用pip与Conda的互操作性

无缝集成的艺术:在Conda中启用pip与Conda的互操作性 引言 Conda是一个强大的包管理器和环境管理器,广泛用于Python和其他科学计算语言。它不仅能够管理包的依赖关系,还能创建和维护独立的开发环境。然而,在某些情况下&#xff0…

cuda中的cooperative_groups

背景 最近看到一个代码cooperative_groups.this_grid().sync()很好奇,这里好好梳理一下 分析 以前block内部的同步是用syncthreads(), block之间没有提供同步的接口,这样是合理的,假如有block间同步API的话,如果block太多&…

Pytorch使用Dataset加载数据

1、前言: 在阅读之前,需要配置好对应pytorch版本。 对于一般学习,使用cpu版本的即可。参考教程点我 导入pytorch包,使用如下命令即可。 import torch # 注意虽然叫pytorch,但是在引用时是引用torch2、神经网络获取…