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

PostgreSQL 中约束Constraints

在 PostgreSQL 中,约束(Constraints)是用于限制进入数据库表中数据的规则。它们确保数据的准确性和可靠性,通过定义规则来防止无效数据的插入或更新。PostgreSQL 支持多种类型的约束,每种约束都有特定的用途和语法。以下是主要的约束类型及其简要说明:

  1. PRIMARY KEY(主键约束)

    • 确保表中每一行的唯一标识。
    • 主键列的值必须唯一且不能为空(NOT NULL)。
    • 一个表只能有一个主键,但主键可以包含多个列(复合主键)。
    CREATE TABLE students (student_id SERIAL PRIMARY KEY,name VARCHAR(100) NOT NULL
    );
    
  2. FOREIGN KEY(外键约束)

    • 确保在一个表中的值在另一个表的主键或唯一键中存在。
    • 用于维护表之间的参照完整性。
    CREATE TABLE enrollments (enrollment_id SERIAL PRIMARY KEY,student_id INT,course_id INT,FOREIGN KEY (student_id) REFERENCES students(student_id),FOREIGN KEY (course_id) REFERENCES courses(course_id)
    );
    
  3. UNIQUE(唯一约束)

    • 确保列中的所有值都是唯一的。
    • 允许空值(NULL),但多个空值不违反唯一性。
    CREATE TABLE students (student_id SERIAL PRIMARY KEY,email VARCHAR(100) UNIQUE
    );
    
  4. CHECK(检查约束)

    • 确保列中的值满足指定的条件。
    • 可以在列级别或表级别定义。
    CREATE TABLE students (student_id SERIAL PRIMARY KEY,age INT CHECK (age >= 0 AND age <= 120)
    );
    
  5. NOT NULL(非空约束)

    • 确保列中的值不能为空。
    • 可以在列定义时直接指定。
    CREATE TABLE students (student_id SERIAL PRIMARY KEY,name VARCHAR(100) NOT NULL
    );
    
  6. EXCLUDE(排除约束)

    • 确保使用指定的运算符(如等于、不等于、小于、大于等)的列组合中的值不会冲突。
    • 通常用于确保地理数据(如经纬度)不会重叠。
    CREATE TABLE circles (circle_id SERIAL PRIMARY KEY,center POINT,radius DOUBLE PRECISION,EXCLUDE USING GIST (circle_with_radius WITH =, circle_with_center WITH &&)
    ) WHERE (radius > 0);
    

    在上面的例子中,circle_with_radiuscircle_with_center 是使用表达式索引定义的虚拟列,用于确保没有两个圆重叠。

  7. DEFAULT(默认值约束)

    • 为列指定默认值,当插入数据时没有为该列提供值时,将使用默认值。
    CREATE TABLE students (student_id SERIAL PRIMARY KEY,enrollment_date DATE DEFAULT CURRENT_DATE
    );
    

通过合理地使用这些约束,可以确保数据库中的数据保持一致性、准确性和完整性。在定义表结构时,应该根据业务需求选择适当的约束来限制数据输入。

http://www.lryc.cn/news/491701.html

相关文章:

  • ✨系统设计时应时刻考虑设计模式基础原则
  • 【Linux】多线程(下)
  • Element-Plus如何修改日期选择器输入框el-date-picker的圆角
  • skywalking es查询整理
  • 故障排除-------K8s挂载集群外NFS异常
  • Easyexcel(6-单元格合并)
  • 解决登录Google账号遇到手机上Google账号无法验证的问题
  • 【Redis_Day5】String类型
  • Python MySQL SQLServer操作
  • Java技术分享
  • CentOS7卸载node
  • LeetCode 2257. Count Unguarded Cells in the Grid
  • 即时通讯服务器被ddos攻击了怎么办?
  • 【大数据学习 | Spark-Core】Spark中的join原理
  • 【代码pycharm】动手学深度学习v2-08 线性回归 + 基础优化算法
  • 李宏毅机器学习课程知识点摘要(1-5集)
  • React(五)——useContecxt/Reducer/useCallback/useRef/React.memo/useMemo
  • UE5时间轴节点及其设置
  • git 命令之只提交文件的部分更改
  • 算法 差分修改 极简
  • pcb元器件选型与焊接测试时的一些个人经验
  • OSG开发笔记(三十三):同时观察物体不同角度的多视图从相机技术
  • 模糊逻辑学习 | 模糊推理 | 模糊逻辑控制
  • 【JavaEE】Servlet:表白墙
  • C++特殊类设计(不能被拷贝的类、只能在堆上创建对象的类、不能被继承的类、单例模式)
  • 【小白学机器学习34】用python进行基础的数据统计 mean,var,std,median,mode ,四分位数等
  • 安装 Docker(使用国内源)
  • Ajax学习笔记,第一节:语法基础
  • 《用Python画蔡徐坤:艺术与编程的结合》
  • Unity中动态生成贴图并保存成png图片实现