有一次和同事讨论起具体的技术细节,同事说不要用什么实体类,从数据库访问到的数据,直接用DataTable、DataSet 就好。理由是,从获取到的数据集转换成实体类,有一定的性能损耗。

呵呵,性能。我们总是有这种无端的担心,一副十分神秘的样子。既然如此,那么为什么还要有ORM、EF这些思想、框架呢?难道创建这些东西的大师们都是在故弄玄虚,过度设计?如果将DataTable转换成实体类有性能损耗,那么这种损耗究竟有多大?跟由此换来的逻辑清晰、开发效率提升是否可以忽略不计?

正如汇编语言的效率高于C、C++等高级语言,但现代操作系统绝大部分功能都用C或C++进行编写。理由是:

1)性能主要在于算法,开发语言之间的性能差距并不起决定性作用

2)高级语言带来的逻辑清晰、代码重用及模块化,结合现代编译技术,有可能比所谓的汇编高手所写的代码性能更好。尤其是复杂性高的模块,人脑跟机器是没办法相比的

3)编译技术的改进,对源代码进行重新编译,可以得到性能更高的成品

4)开发过程中,先使用C等高级语言编写,调试、定位成功以后,关键部分再采用汇编改写,这种思路更利于成功

另外,同事说,使用DataTable和使用实体类并没有区别。“想想看,如果增加了一个字段,实体类不是照样要修改吗?引用实体类的代码也要相应修改,这跟使用DataTable有什么不同?”同事理直气壮地问我。

我一时语塞,想不出什么理由反驳,只好弱弱地说:“那字段名修改了,实体类的属性可以不一定修改”

“通常,数据库的字段名字改了,实体类属性也要改吧,不然容易误解”

我更加哑口无言,无奈地说:“但是将数据库的东西,直接塞在前端,即UI层面,总不大好吧。。。“。说实在的,为什么要分层,为什么要将数据与UI分离,我只是人云欲云。虽然我认同分层确属必要,但这个问题我真没好好考虑过。

不过后来我静下来想了想,增加字段、改字段名、字段类型,实体类照样要修改没错;但如果去掉一些字段,那么实体类方式的优势就出来了。假如页面端直接用DataTable 访问,那么字段去掉以后,编译阶段,是发现不了错误的;但实体类不同,数据库字段删掉了,实体类应该也跟着删掉了相应属性,那么所有调用这个实体类属性的地方,编译时就会报错。如果我们在VS中,使用重构,还可以自动修正过来。

版权声明:本文为博主原屙文章,喜欢你就担走。

WEB端应该使用DataTable/DataSet吗?的更多相关文章

  1. Newtonsoft.Json高级用法DataContractJsonSerializer,JavaScriptSerializer 和 Json.NET即Newtonsoft.Json datatable,dataset,modle,序列化

    原文地址:https://www.cnblogs.com/yanweidie/p/4605212.html Newtonsoft.Json介绍 在做开发的时候,很多数据交换都是以json格式传输的.而 ...

  2. Newtonsoft.Json高级用法,json序列号,model反序列化,支持序列化和反序列化DataTable,DataSet,Entity Framework和Entity,字符串

    原文地址:https://www.cnblogs.com/yanweidie/p/4605212.html 手机端应用讲究速度快,体验好.刚好手头上的一个项目服务端接口有性能问题,需要进行优化.在接口 ...

  3. 移动web端的react.js组件化方案

     背景: 随着互联网世界的兴起,web前端开发的方式越来越多,出现了很多种场景开发的前端架构体系,也对前端的要求日益增高,早已经不是靠一个JQuery.js来做前端页面的时代了,而今移动端变化最大,近 ...

  4. web端限时活动逻辑处理总结

    由于要在web端做一个限时活动的功能,功能大致为:一个小时内可以报名参加活动,然后给予报名者奖品,先到先得.用到一些处理逻辑做下总结,以前没有做过类似的东西,都是自己先体验其他网站的报名方式,然后再摸 ...

  5. 小程序 web 端实时运行工具

    微信小程序 web 端实时运行工具 https://chemzqm.github.io/wept/

  6. 力软信息化系统快速开发框架 web端+winform端

    力软信息化系统快速开发框架是一套集权限管理+快速开发+动态接口+通用组件+动态UI于一体的全新.net信息化快速开发框架.力软信息化系统快速开发框架的使用,大大地缩短了开发周期,提高了软件质量,同时也 ...

  7. 基于SignalR的web端即时通讯 - ChatJS

    先看下效果. ChatJS 是基于SignalR实现的Web端IM,界面风格模仿的是“脸书”,可以很方便的集成到已有的产品中. 项目官网:http://chatjs.net/ github地址:htt ...

  8. Web端即时通讯技术盘点:短轮询、Comet、Websocket、SSE

    1. 前言 Web端即时通讯技术因受限于浏览器的设计限制,一直以来实现起来并不容易,主流的Web端即时通讯方案大致有4种:传统Ajax短轮询.Comet技术.WebSocket技术.SSE(Serve ...

  9. 新手入门:史上最全Web端即时通讯技术原理详解

    前言 有关IM(InstantMessaging)聊天应用(如:微信,QQ).消息推送技术(如:现今移动端APP标配的消息推送模块)等即时通讯应用场景下,大多数都是桌面应用程序或者native应用较为 ...

随机推荐

  1. React开发实时聊天招聘工具 -第四章 Redux

    复杂以后 setState 就不太方便了 所以使用Redux来管理 React只负责View. Store.State.Dispatch.Reducer reducer(state,action) { ...

  2. 笔试算法题(39):Trie树(Trie Tree or Prefix Tree)

    议题:TRIE树 (Trie Tree or Prefix Tree): 分析: 又称字典树或者前缀树,一种用于快速检索的多叉树结构:英文字母的Trie树为26叉树,数字的Trie树为10叉树:All ...

  3. delphi GDI+ [1]

    摘抄自:万一的博客 安装头文件:http://www.cnblogs.com/del/archive/2008/06/06/1215319.html 目录 基本使用方法(绘制直线) 绘制一组直线 绘制 ...

  4. jquery 点击弹框

    <a href="#" class="big-link" data-reveal-id="myModal" data-animatio ...

  5. 如何判断CPU、内存、磁盘的性能瓶颈?

    1.如何判断CPU.内存.磁盘的瓶颈? CPU瓶颈1) 查看CPU利用率.建议CPU指标如下 a) User Time:65%-70% b) System Time:30%-35% c) Idle:0 ...

  6. C语言《一维数组的学习,冒泡排序》

    #include<stdio.h> /* 一维数组的学习,冒泡排序 soulsjie 20170623 */ void main(){ int a[6]; int i,j,k; print ...

  7. 2017icpc 西安 XOR

    XOR Consider an array AAA with n elements . Each of its element is A[i]A[i]A[i] (1≤i≤n)(1 \le i \le ...

  8. LaTex/Overleaf使用笔记

    1. 添加网页引用 @misc{ r1,   author = "Wikipedia",   title = "Binary decision diagram --- { ...

  9. POJ-20407Relatives/NYOJ-333mdd的烦恼,欧拉函数简单应用,模板A

     poj                         Relatives                                Time Limit: 1000MS   Memory Li ...

  10. WebLoad 解析服务器返回的JSON格式内容

    服务器返回Json格式的响应内容经常是以 String (txt) 形式返回给客户端.客户端需要把 文本形式的内容还原为Json格式以进一步做处理(如,取得返回内容的一个值作为下个请求的一个输入).这 ...