不等值联结 mysql_mysql的自联结、自然联结、内部联结、等值联结、不等值联结、外部联结、交叉联结等替你整理好了,爱看不看。...

自联结

就是一个表自己和自己联结,一般用来替代子查询

比如班上有1个学生数学考了100分,你不知道他是谁,你想知道他的其他学科的成绩

新手的写法

select student_id from score where type='mathematics' and score=100(假设结果为27)

select * from score where student_id=27

或者

select * from score where student_id=(

select student_id from score where type='mathematics' and score=100

)

自联结的写法

select t1.* from score as t1,score as t2 where t1.student_id=t2.student_id and t2.type='mathematics' and t2.score=100

select t1.* from score as t1 inner join score as t2 on t1.student_id=t2.student_id where t2.type='mathematics' and t2.score=100

自然联结

无论何时对表进行联结,应该至少有一个列出现在不止一个表中(被联结的列)

标准的联结返回所有数据,甚至相同的列多次出现

自然联结排除多次出现,使每个列只返回一次

数据库通过自己的判断并使用表内所有相同的字段作为联结条件完成联结过程,不需要指定联结条件

一般的写法是第1个表用*指定字段,其他的表用明确的表字段指定

最好不要让数据库自动完成联结,不推荐使用

select * from t1 natural join t2(效果有点类似inner join)

select * from t1 natural left join t2(效果有点类似left join)

select * from t1 natural right join t2(效果有点类似right join)

内部联结(又叫等值联结)

联结的2个表必须联结条件匹配才会得到数据

内部联结一般都是自然联结,很可能我们永远都不会用到不是自然联结的内部联结

select a.f1,b.f2 from a,b where a.f3=b.f4(不推荐这样的写法)

select a.f1,b.f2 from a inner join b on a.f3=b.f4(inner关键字可以省略)

如果两个表是根据字段名一样的字段联结的,可以这样写

select t1.id,t2.name from t1 inner join t2 using(f)

外部联结

外部联结根据情况来确定是否包含那些在相关表中没有匹配的行

1.左外部联结(又叫左联结)

左表的行一定会列出,右表如果没有匹配的行,那么列值就为null

特别需要注意的是如果右表有多行和左表匹配,那么左表相同的行会出现多次

select a.f1,b.f2 from a left outer join b on a.f3=b.f4(outer关键字可以省略)

2.右外部联结(又叫右联结)

和左联结类似,只不过以右表为主表而已,左联结和右联结可以相互转化

select a.f1,b.f2 from a right outer join b on a.f3=b.f4(outer关键字可以省略)

3.全外部联结

返回左表和右表的所有行,不管有没有匹配,同时具有左联结和右联结的特性

select a.f1,b.f2 from a full outer join b on a.f3=b.f4(outer关键字可以省略)

交叉联结

生成笛卡尔积,它不使用任何匹配或者选取条件,而是直接将一个数据源中的每个行与另一个数据源的每个行都一一匹配

select * from a cross join b

UNION和UNION ALL

UNION不允许同一行(每个字段都一样)重复出现,而UNION ALL则没有这个限制

select A,B from u1

union all

select A,B from u2

关于联结的示意图

85a6dd586f9c6d1009b902ddbfb9844e.png

基于SSM框架的智能家政保洁预约系统,是一个旨在提高家政保洁服务预约效率和管理水平的平台。该系统通过集成现代信息技术,为家政公司、家政服务人员和消费者提供了一个便捷的在线预约和管理系统。 系统的主要功能包括: 1. **用户管理**:允许消费者注册、登录,并管理他们的个人资料和预约历史。 2. **家政人员管理**:家政服务人员可以注册并更新自己的个人信息、服务类别和服务时间。 3. **服务预约**:消费者可以浏览不同的家政服务选项,选择合适的服务人员,并在线预约服务。 4. **订单管理**:系统支持订单的创建、跟踪和管理,包括订单的确认、完成和评价。 5. **评价系统**:消费者可以在家政服务完成后对服务进行评价,帮助提高服务质量和透明度。 6. **后台管理**:管理员可以管理用户、家政人员信息、服务类别、预约订单以及处理用户反馈。 系统采用Java语言开发,使用MySQL数据库进行数据存储,通过B/S架构实现用户与服务的在线交互。系统设计考虑了不同用户角色的需求,包括管理员、家政服务人员和普通用户,每个角色都有相应的权限和功能。此外,系统还采用了软件组件化、精化体系结构、分离逻辑和数据等方法,以便于未来的系统升级和维护。 智能家政保洁预约系统通过提供一个集中的平台,不仅方便了消费者的预约和管理,也为家政服务人员提供了一个展示和推广自己服务的机会。同时,系统的后台管理功能为家政公司提供了强大的数据支持和决策辅助,有助于提高服务质量和管理效率。该系统的设计与实现,标志着家政保洁服务向现代化和网络化的转型,为管理决策和控制提供保障,是行业发展中的重要里程碑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值