• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

data access layer - What is DTO equivalent term for objects returned from DAL?

[复制链接]
菜鸟教程小白 发表于 2022-6-22 20:04:37 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

I'm already using DTO's for data transfer over a network. Now I'm also introducing different DTO-like classes to the DAL. This is to avoid passing the application (business) objects across layers.

To avoid naming confusion, I would like to use another term than DTO but can't find a good one.

What is DTO equivalent term for objects returned from DAL?



Best Answer-推荐答案


"What's in a name? that which we call a rose by any other name would smell as sweet." - William Shakespeare

Also, what Martin Fowler says about POJO:

In the talk we were pointing out the many benefits of encoding business logic into regular java objects rather than using Entity Beans. We wondered why people were so against using regular objects in their systems and concluded that it was because simple objects lacked a fancy name. So we gave them one, and it's caught on very nicely.

By the way, it does not matter that much. Looking at your concern to avoid confusion due to similar naming, you may choose from "DataModel", "Entity", "POCO".

Following are very loose considerations for different terms generally used:

Relational Model [Database Layer]:

  • Database, tables and fields.

Persistence Model [Data Access Layer]:

  • Model that (generally) belongs to ORMs or closely map with database.
  • This is used for persistence needs.

Domain Model/Business Model [Business Logic/Services Layer]:

  • Model that is exposed to BLL/Service Layer.

View Model [UI Layer]:

  • Model that is exposed to View.

DTO:

  • Holds only state and used to transfer data from one layer to other.
  • Does not have any behaviour/logic except serialization.
  • Preferably serializable.
  • Designed against requesting layer; does not resemble with database.
  • Does NOT have its own identity.

POCO:

  • It is simply a regular object that has no references to any specific framework and does not follow their interfaces or restrictions.
  • Persistence ignorant objects that can be used with any ORM.
  • Holds data from database.
  • Not necessarily serializable.
  • Designed against database request.
  • May have logic for validation or other that is tightly bound to POCO (like data encryption/uniqueness of column).
  • Does NOT have persistence methods like Get, Save etc. POCO does not fill itself.
  • MAY have its own identity.

Entity:

  • It MUST have its own identity and can be uniquely identified.
  • Object that can be loaded from and saved to a database using a DataContext.
  • Cannot exist without its DataBaseContext.
  • Tightly bound with specific ORM and implements its rules (default constructor, virutal properties to create runtime proxies etc.).
  • Entities represent domain model and domain logic.

Model:

  • Common term used to represent any object that holds data.
  • All objects above, if we put any of it in MV* pattern, it becomes Model.

Refer following answers:

https://stackoverflow.com/a/37751345/5779732

https://stackoverflow.com/a/42801839/5779732

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap