0

0

mysql数据库对象关系映射_MySQL

php中文网

php中文网

发布时间:2016-06-01 13:29:19

|

1648人浏览过

|

来源于php中文网

原创

bitsCN.com

mysql数据库对象关系映射

 

1.对“对象关系映射”的理解

 

a.对象:可以理解为java中的类

 

b.关系:可以理解为数据库的表

 

c.映射:这是因为java中的数据的类型与数据库的数据类型是有些不同的,如何将java中的类型的数据用数据库中的数据类型来存储起来,这就映射。

 

同时,还有当java中的两个对象之间是有关系的,那么在存储在数据库中时,也需要用一种方式来体现出这种存在的关系,而不能是两个

 

不相关的两张表,这也需要映射出来这种关系。

 

2.表与表之间的关系类型可以分为以下四种:

 

多对一,一对多,多对多,一对一

 

3.分别对这四处种关系进行示例说明

 

a.多对一(一对多和多对一,其实是看的角度不同,实际上可以看成同一种)员工与部门之间的关系

 

有以下两个java对象:

 

对象类:

 

[java] Department  int id;  String name;  Set employees=new HashSet();    Employee  int id;  String name;  Department dept;  

 

员工与部门,这两者是典的多对一的关系,多个员工可以属于同一个部门,一个部门中可以有多个员工。

注意:在实际开发时,如果要设计一个员工管理系统,那么在进行对象实体类的设计时,就是按照上面

 

设计方式来设计员工类和部门类。在员工 类中有一个Department dept属性,而没有直接用int dept_no,

 

因为样更加符面象对象的设计思想。

 

对应的数据库的表为:

 

[sql] create department(  id int primary key,  name varchar(20)  );  [sql] create employee(  id int primary key,  name varchar(20),  dept_id int,  constraint dept_id_FK foreign key(dept_id) references department(id)  );  

 

注:两个表之间的关系,多对一,用外键来体现。一般外键的应该放在多的一方,在这里也就是放在employee员工表中。

 

b.多对多的关系 学生与老师之间的关系

citySHOP多用户商城系统
citySHOP多用户商城系统

citySHOP是一款集CMS、网店、商品、分类信息、论坛等为一体的城市多用户商城系统,已完美整合目前流行的Discuz! 6.0论坛,采用最新的5.0版PHP+MYSQL技术。面向对象的数据库连接机制,缓存及80%静态化处理,使它能最大程度减轻服务器负担,为您节约建设成本。多级店铺区分及联盟商户地图标注,实体店与虚拟完美结合。个性化的店铺系统,会员后台一体化管理。后台登陆初始网站密匙:LOVES

下载

 

java类对象:

 

[java] Teacher  int id;  String name;  Set students=new HashSet();    Student  int id;  String name;  Set teachers=new HashSet();  

 

 

对应的数据库中的表:

 

[sql] create table teacher(  id int primary key,  name varchar(20)  );  create table student(  id int primary key,  name varchar(20)  );  

 

注:对于多对多的关系,应该创建第三张表来保存两张表的映射关系

 

[sql] create table student_teacher(  student_id int,  teacher_id int,  constraint student_teacher_PK primary key(student_id,teacher_id),  constraint student_id_FK foreign key(student_id) references student(id),  constraint teacher_id_FK foreign key(teacher_id) references teacher(id)  );  

 

第三张中的主键是以前两张表的主键作为复合主键,并分别以两张表的主键作为外键。

 

 

 

c.一对一的关系 人与身份证之间的关系

 

java类对象:

 

[java] Person  int id;  String name;  IdCard ic;    IdCard  int id;  String address;  

 

 

对应的数据库表为:

 

[sql] create table person(  id int primary key,  name varchar(20)  );    create table idcard(  id int primary key,  address varchar(40),  constraint id_FK foreign key(id) references person(id)  );  

 

 

注:对于一对一关系的两张表,分主表与从表,从表的存在必须依赖于主

表,主表可以不依赖于从表。从表的设计上其主键字段同时也是外键字段。

 

备注:有时在设计表时,会特意把两张表合在一张表中,虽然会造成

 

数据冗余,但是却可以不因为联表查询而造成查询性能有所降低。这是用

 

空间来换时间的做法。

 

bitsCN.com

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Golang 并发编程模型与工程实践:从语言特性到系统性能
Golang 并发编程模型与工程实践:从语言特性到系统性能

本专题系统讲解 Golang 并发编程模型,从语言级特性出发,深入理解 goroutine、channel 与调度机制。结合工程实践,分析并发设计模式、性能瓶颈与资源控制策略,帮助将并发能力有效转化为稳定、可扩展的系统性能优势。

0

2026.02.27

Golang 高级特性与最佳实践:提升代码艺术
Golang 高级特性与最佳实践:提升代码艺术

本专题深入剖析 Golang 的高级特性与工程级最佳实践,涵盖并发模型、内存管理、接口设计与错误处理策略。通过真实场景与代码对比,引导从“可运行”走向“高质量”,帮助构建高性能、可扩展、易维护的优雅 Go 代码体系。

0

2026.02.27

Golang 测试与调试专题:确保代码可靠性
Golang 测试与调试专题:确保代码可靠性

本专题聚焦 Golang 的测试与调试体系,系统讲解单元测试、表驱动测试、基准测试与覆盖率分析方法,并深入剖析调试工具与常见问题定位思路。通过实践示例,引导建立可验证、可回归的工程习惯,从而持续提升代码可靠性与可维护性。

0

2026.02.27

漫蛙app官网链接入口
漫蛙app官网链接入口

漫蛙App官网提供多条稳定入口,包括 https://manwa.me、https

49

2026.02.27

deepseek在线提问
deepseek在线提问

本合集汇总了DeepSeek在线提问技巧与免登录使用入口,助你快速上手AI对话、写作、分析等功能。阅读专题下面的文章了解更多详细内容。

4

2026.02.27

AO3官网直接进入
AO3官网直接进入

AO3官网最新入口合集,汇总2026年可用官方及镜像链接,助你快速稳定访问Archive of Our Own平台。阅读专题下面的文章了解更多详细内容。

37

2026.02.27

php框架基础教程
php框架基础教程

本合集涵盖2026年最新PHP框架入门知识与基础教程,适合初学者快速掌握主流框架核心概念与使用方法。阅读专题下面的文章了解更多详细内容。

1

2026.02.27

php框架怎么用
php框架怎么用

本合集专为零基础学习者打造,系统介绍主流PHP框架的安装、配置与基础用法,助你快速入门Web开发。阅读专题下面的文章了解更多详细内容。

3

2026.02.27

无禁词AI聊天软件下载大全
无禁词AI聊天软件下载大全

本合集精选多款免费、无违禁词限制的AI聊天软件,支持自定义角色、剧情畅聊,体验真实互动感。阅读专题下面的文章了解更多详细内容。

7

2026.02.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.8万人学习

Django 教程
Django 教程

共28课时 | 4.6万人学习

Excel 教程
Excel 教程

共162课时 | 19.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号