1. 选择(Selection):从关系中选择满足特定条件的元组。 示例:选择所有年龄大于30的员工。 ```sql SELECT FROM Employees WHERE Age > 30; ```
2. 投影(Projection):从关系中选择特定的属性。 示例:选择员工的姓名和年龄。 ```sql SELECT Name, Age FROM Employees; ```
3. 并(Union):将两个关系中的元组合并,去除重复的元组。 示例:合并两个员工表中的元组。 ```sql SELECT FROM EmployeesA UNION SELECT FROM EmployeesB; ```
4. 差(Difference):从一个关系中减去另一个关系中存在的元组。 示例:从A员工表中减去B员工表中的元组。 ```sql SELECT FROM EmployeesA EXCEPT SELECT FROM EmployeesB; ```
5. 交(Intersection):找出两个关系中共同存在的元组。 示例:找出A员工表和B员工表中共同存在的元组。 ```sql SELECT FROM EmployeesA INTERSECT SELECT FROM EmployeesB; ```
6. 自然连接(Natural Join):基于两个关系中具有相同名称的属性进行连接。 示例:基于员工ID连接员工表和部门表。 ```sql SELECT FROM Employees NATURAL JOIN Departments; ```
7. 等值连接(Equi Join):基于两个关系中具有相同值的属性进行连接。 示例:基于员工ID和部门ID连接员工表和部门表。 ```sql SELECT FROM Employees JOIN Departments ON Employees.DepartmentID = Departments.DepartmentID; ```
8. 笛卡尔积(Cartesian Product):将两个关系的所有元组进行组合。 示例:将员工表和部门表的所有元组进行组合。 ```sql SELECT FROM Employees CROSS JOIN Departments; ```
9. 外连接(Outer Join):包括左外连接(Left Outer Join)、右外连接(Right Outer Join)和全外连接(Full Outer Join),用于保留连接时被忽略的元组。 示例:左外连接员工表和部门表。 ```sql SELECT FROM Employees LEFT JOIN Departments ON Employees.DepartmentID = Departments.DepartmentID; ```
10. 除法(Division):找出一个关系中满足另一个关系中所有条件的元组。 示例:找出所有部门中都有员工工作的部门。 ```sql SELECT FROM Departments WHERE NOT EXISTS qwe2; ```
这些操作可以组合使用,以实现更复杂的查询。例如,你可以使用选择、投影和连接的组合来查询特定条件下的员工信息。
数据库关系代数例题详解
一、关系代数的基本概念
关系:一个关系可以看作是一个二维表,其中每一行代表一个元组,每一列代表一个属性。
元组:关系中的一行,代表一个实体或记录。
属性:关系中的一列,代表实体的一个特征或属性。
域:属性的取值范围。
二、关系代数运算
关系代数运算包括传统的集合运算和专门的关系运算。
1. 传统的集合运算
并(∪):将两个关系合并为一个新关系,包含两个关系中所有的元组。
交(∩):取两个关系的交集,包含同时属于两个关系的元组。
差(-):取两个关系的差集,包含属于第一个关系但不属于第二个关系的元组。
笛卡尔积(×):将两个关系合并为一个新关系,包含所有可能的元组组合。
2. 专门的关系运算
选择(σ):根据给定条件从关系中选取满足条件的元组。
投影(π):从关系中选取若干属性列,形成一个新的关系。
连接(?):将两个关系按照指定的条件进行合并,形成一个新的关系。
三、关系代数例题详解
例题1:给定两个关系R和S,求R和S的并集。
假设关系R和S如下:
属性
值
A
1
B
2
属性
值
A
3
B
4
解:R和S的并集包含两个关系中所有的元组,因此并集为:
属性
值
A
1
B
2
A
3
B
4
例题2:给定关系R,求满足条件A=2的元组。
假设关系R如下:
属性
值
A
1
B
2
A
2
B
3
解:满足条件A=2的元组为:
属性
值
A