entity、model和domain三者区别

实体(entity)、模型(model)和域(domain)在软件开发中分别扮演不同角色。实体通常与数据库字段保持一致,方便ORM框架操作。模型主要用于前端展示,根据需求提供定制化的数据结构,避免数据冗余或处理复杂逻辑。域则更关注业务对象,整合多个数据源,为复杂场景提供完整对象。合理使用它们能提高代码的可维护性和效率。
摘要由CSDN通过智能技术生成

先用三句话来简单描述一下他们各自的特点:

名称

特点

entity

字段必须和数据库字段一样

model

前端需要什么我们就给什么

domain

比较少用,代表一个对象模块

1.entity实体

entity就是实体的意思,也是我们最常用到的。entity包中的类是必须和数据库相对应的比如说:数据库有个user表,字段有long类型的id,string类型的姓名,那么entity中的user类也必须是含有这两个字段的,且类型必须一致。不能数据库存的是long类型,user类里的属性是string类型。

这样做的好处是保持实体类和数据库保持一致,另外,当用到hibernate或mybatie框架来操作数据库的时候,操作这个实体类就行,写sql之前不需要再做数据格式处理。

2.model模型

model大家不陌生,都知道是模型的意思,当用model当包名的时候,一般里面存的是实体类的模型,一般是用来给前端用的。比如:前端页面需要显示一个user信息,user包含姓名,性别,年龄,这些信息存在数据库的时候,姓名直接存姓名,但是性别和年龄一般会用数据字典的编号存到数据库,比如:1代表男,2代表女,数据库存的就是1或2,如果用entity的话,把1、2给前端,前端就不知道是什么玩意,就算前端知道1代表男,2代表女,写了一个js判断数据处理,后来数据库变动了,1代表女,2代表男,前端的js又需要重新写,很显然这样不利于维护。所以就需要model来解决,后台从数据库取了数据转化为前端需要的数据直接传给前端,前端就不需要对数据来处理,直接显示就行了还有一种情况,数据库里面的user表字段有十个,包含姓名,qq,生辰八字乱七八糟的等等,但是前台页面只需要显示姓名,如果把entity全部传给前台,无疑传了很多没用的数据。这时候model就很好的解决了这个问题,前台需要什么数据,model就包含什么数据就行了

3.domain域

domain这个包在国外很多大型项目经常用到,字面意思是域的意思。它的范围就有点广了,比如一个商城的项目,商城主要的模块就是用户,订单,商品三大模块,那么这三块数据就可以叫做三个域,domain包里就是存的就是这些数据,表面上这个包和entity和model包里存的数据没什么区别,其实差别还是挺大的,特别是一些大型的项目。比如一个招聘网站的项目,最重要的对象就是简历了,那么简历是怎么存到数据库的呢,不可能用一张表就能存的,因为简历包含基本信息和工作经验,项目经验,学习经验等。基本信息可以存在简历表,但是涉及到多条的就不行,因为没人知道有多少条工作经验,项目经验,所以必须要单独建工作经验表和项目经验表关联到简历基本信息表。但是前台页面是不关心这些的,前台需要的数据就是一个简历所有信息,这时就可以用到domain来处理,domain里面的类就是一个简历对象,包含了简历基本信息以及list的工作经验,项目经验等。这样前端只需要获取一个对象就行了,不需要同时即要获取基本信息,还要从基本信息里面获取工作经验关联的简历编号,然后再去获取对应的工作经验了。

当然,如果用model的话也是可以达到domain的效果的。这个完全是看个人喜好和项目的整体架构,因为创建不同的package的作用本来也就是想把项目分成不同的层,便于管理和维护。如果你乐意,你可以创建entity包,然后在里面存图片,创建images文件夹,里面存js。你自己能看懂就行,前提是如果是团队开发的话能保证别人不打你。这个和语言一个道理,你在200前和英国人说:private void set(int age),人家说:滚犊子;现在你这样说,人家就知道是java语言了。能被人们通用的才叫语言,你说的别人听不懂那只能算是鸟语。所以开发的时候,建类建包的命名规则规范性还是很重要的。

  • 12
    点赞
  • 47
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 11
    评论
评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

宋文轩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值