1. 关系(Relation)
    假设我们有一个学生表 students,它包含学生的学号 id、姓名 name 和年龄 age 等属性,那么这个表就是一个关系。
    CREATE TABLE students (
        id INT PRIMARY KEY,
        name VARCHAR(50),
        age INT
    );
  1. 元组(Tuple)
    表中的每一行都是一个元组。例如,在 students 表中,(1, '张三', 20) 就是一个元组。

    在 Python 中,元组(tuple)是一种数据结构,与关系数据库中的元组概念有一些相似之处,但也存在一些区别。

    在关系数据库中,元组是关系中的一行,表示一个具体的实体或记录。

    而在 Python 中,元组是一种有序的、不可变的序列,它可以包含多个元素,这些元素可以是不同的数据类型。

    例如,在 Python 中,可以创建一个元组如下:

     
    my_tuple = (1, 'hello', 3.14)
    
     

    这里的 my_tuple 就是一个元组,它包含了三个元素:整数 1、字符串 'hello' 和浮点数 3.14。

     

    虽然 Python 中的元组和关系数据库中的元组在概念上有一些相似之处,但它们的用途和使用场景是不同的。

     

    Python 中的元组是一种数据结构,用于存储一组相关的数据,而关系数据库中的元组是关系中的一行,用于表示一个具体的实体或记录。

  2. 属性(Attribute)
    students 表中的 idname 和 age 就是属性。

  3. 域(Domain)
    例如,age 属性的域可以是整数,取值范围在 0 到 150 之间。在创建表时可以指定属性的数据类型来限制域。

    CREATE TABLE students (
        id INT PRIMARY KEY,
        name VARCHAR(50),
        age INT CHECK (age >= 0 AND age <= 150)
    );

  1. 主键(Primary Key)
    在 students 表中,我们可以将 id 属性设置为主键,确保每个学生的学号是唯一的。

    CREATE TABLE students (
        id INT PRIMARY KEY,
        name VARCHAR(50),
        age INT
    );

  1. 外键(Foreign Key)
    假设我们还有一个课程表 courses,包含课程编号 course_id 和课程名称 course_name,以及一个选课表 enrollments,包含学生学号 student_id 和课程编号 course_id。在 enrollments 表中,student_id 和 course_id 可以分别作为外键,引用 students 表的 id 和 courses 表的 course_id
    CREATE TABLE courses (
        course_id INT PRIMARY KEY,
        course_name VARCHAR(50)
    );

    CREATE TABLE enrollments (
        student_id INT,
        course_id INT,
        FOREIGN KEY (student_id) REFERENCES students(id),
        FOREIGN KEY (course_id) REFERENCES courses(course_id)
    );

外键的作用主要包括以下几点:

  1. 维护数据的一致性和完整性:通过外键约束,可以确保相关表之间的数据一致性。例如,在一个订单管理系统中,订单表中的客户 ID 可以作为外键引用客户表中的主键,这样可以保证每个订单都对应一个有效的客户。
  2. 建立表与表之间的关联:外键定义了表之间的关系,使得可以在查询时方便地关联多个表,获取相关的数据。例如,可以通过外键关联查询订单表和客户表,获取订单对应的客户信息。
  3. 防止数据冗余:通过外键引用其他表中的数据,可以避免在多个表中重复存储相同的数据,从而减少数据冗余。
  4. 加强数据的约束:外键约束可以限制对数据的操作,例如,当存在外键约束时,不能删除被其他表引用的主键数据,否则会导致外键约束失败。

假设我们有两个数据表,一个是 “学生表”,另一个是 “班级表”。

学生表的属性可能有

  • 学生编号:用来唯一标识每个学生。
  • 学生姓名:记录学生的名字。
  • 年龄:学生的岁数。
  • 班级编号:这个就是外键,它指向班级表中的班级编号,通过这个属性可以知道这个学生属于哪个班级。

班级表的属性可能有

  • 班级编号:唯一标识每个班级。
  • 班级名称:比如 “一班”“二班” 等。

在这个例子中,学生表中的 “班级编号” 是外键,它引用了班级表中的 “班级编号”,建立了学生和班级之间的关联。这样通过外键,我们可以很容易地找到某个学生所在的班级,也可以找到一个班级中的所有学生。

外键也就其他表中的主键

外键通常是一个表中的一列或多列,它的值与另一个表中的主键相匹配。

例如,有两个表 A 和 B。表 A 的主键是 ID,表 B 中有一列外键 FK,它引用了表 A 的 ID。这样,通过 FK,表 B 中的记录可以与表 A 中的特定记录相关联。

这种设计有助于维护数据的一致性和完整性。如果表 B 中的一条记录的外键值在表 A 中找不到对应的主键值,那么这种情况通常是不被允许的,数据库系统可能会报错或采取其他约束措施。

总之,外键是建立表与表之间关系的重要手段,它通常引用其他表中的主键来确保数据的关联性和准确性。

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐