`
yang_min
  • 浏览: 343008 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

数据库时代的终结

阅读更多
以数据库为核心的软件时代已经过去,数据库时代早已结束,当我看到J2EE征途中那么多人在对象和数据库之间彷徨痛苦ing的时候,我想我该出来喊一声了。

  其实这句话在几年前肯定有人喊过,因为中间件时代的来临,实际意味着数据库时代终结,正所谓一山无二虎:如果你重视数据库,你的J2EE系统就无法完全OO,只有你忽视数据库,你的系统才有可能完全迈向OO,至于数据库性能调优等特定功能都可交由EJB容器或O/R Mapping工具实现。

  很多年前,包括我自己在内的大部分企业程序员都是从数据库开始我们的职业生涯,最早的是dBase/FoxPro,后来有了 SQL系列数据库, Oracle将数据库时代推向了顶峰。

  每当有一个新项目时,第一步就是首先设计出数据表结构(Table Schema),然后开始使用SQL语句实现业务逻辑,这种开发模式一直重复,就是后来加入了DelPhI/VB,他们也只是承担图形显示实现,这种C/S结构带来最大问题是:非常难于维护,修改起来,迁一动百。

  软件的生命在于运动,当它需要发展时,最棒的软件人员如果对他也束手无策,这是谁的悲哀?

  现在更多人开始接受B/S结构,但是他们中很多人还没有真正明白为什么需要B/S结构,B/S代表的多层架构才是真正目的(因此,伪多层的B/S系统遍地皆是)。

  多层架构实际是将以前系统中的显示功能、业务运算功能和数据库功能完全分开,杜绝彼此的耦合与影响,从而实现松耦合和良好的可维护性。

  一. 从设计上说:由于实现层次完全分离,业务运算功能成为一种中间功能(中间层),它不依赖具体的表现层技术(Jsp/Html applet等),也不依赖具体数据库技术(Oracle/SQL Server),业务运算功能运行在J2EE应用服务器中,当我们的业务运算功能不再依赖数据库时,是否意味着数据库已经不是重点?

  二. 当然,多层结构带来了性能问题:客户端访问数据库中的数据时,通常需要经过多个层次,非常耗费性能, 如何尽量减少数据库访问是J2EE应用系统首要解决的问题,使用存储过程并没有解决这个问题,存储过程的执行还是属于后端,并没有缩短客户端请求所要经历的坎坷路途。

  解决性能问题的根本解决之道是使用对象缓存,现在, 64位CPU提供的巨大内存空间为单台缓存计算提供了硬件基础,更重要的是,这种缓存计算是可伸缩的,通过集群的缓存机制(如JBossCache), 通过增加应用服务器的数量,可以提高整个业务逻辑层的缓存计算能力,抛弃过去那种为内存斤斤计较的老思维吧。

  三. 在系统分析之初是否首先需要数据表设计呢?回答是否定的, 以UML为代表面向对象的分析设计方法已经成为强大工具,随着面向模型驱动分析设计(MDA)的普及, 面向数据库分析方法正在逐步被抛弃,拥有深厚传统数据库分析习惯的程序员必须面对和接受这种挑战。

  纵观整个J2EE系统开发过程,数据库已经从过去的中心位置降为一种纯技术实现,数据库只是状态持久化的一种手段(文件是另外一种实现手段);什么是持久化?这是相对于内存缓存状态而言,持久化就是当内存断电情况下能永久保存状态数据,但是如果J2EE应用服务器是7X24小时集群运行;几乎永不当机,是否有持久化的必要呢?

  很显然,数据库已经沦为与操作系统中文件系统同样的层面,以它为中心的时代真的结束了,IBM早期将DB2数据库开源已经强烈向我们昭示这点。

  对于J2EE初学者来说,尽早抛弃过去的两种影响:过程语言编程习惯和以数据库为中心的设计习惯,从全新的面向对象角度(OOA、OOD和OOP、AOP)来设计开发你的J2EE系统,J2EE设计开发三件宝:Model、Patterns和Framework。

  以上不只是理论,而是我每天正在做的,如果你也是或赞同请广为传播,唤醒更多彷徨痛苦的初学者。
分享到:
评论

相关推荐

    一个用于 InfluxDB 时序数据库的 ORM,终结没有 InfluxDB ORM 的时代

    一个用于 InfluxDB 时序数据库的 ORM,终结没有 InfluxDB ORM 的时代。常用操作一把梭,支持 php-fpm、Swoole 环境,一键轻松切换。可以用于所有传统框架、所有 Swoole 框架中!

    C#2.0代码生成器,关于数据库代码

    在C# 2.0时代,代码生成器的运用是提高开发效率的重要手段之一。通过解析数据库的结构,如表、字段、主键、外键等信息,该工具可以自动生成对应的C#类和接口,这些类和接口能够直接用于数据操作。例如: 1. **...

    青创文章.NET2002(终结版)

    在.NET框架2002的时代,微软首次引入了.NET Framework,这是一个全面的开发平台,包含了运行应用程序所需的各种服务,如类库、编译器和执行环境(CLR)。这一时期的.NET框架主要关注Windows应用程序的开发,包括...

    【海码站】影视系统终结版.zip

    随着数字时代的到来,互联网已经成为人们生活中不可或缺的一部分,尤其是在线视频平台的兴起,为用户提供了丰富多彩的娱乐和学习资源。而搭建一个属于自己的视频网站,不仅能够满足个人兴趣爱好,还能在技术领域进行...

    [新闻文章]青创文章.Net(终结版)_qc_net_a(ASP.NET源码).rar

    在互联网技术日新月异的时代,ASP.NET作为微软公司推出的Web应用程序开发框架,以其高效、安全、易用的特点,深受开发者喜爱。本文将深入探讨【新闻文章】青创文章.Net(终结版)_qc_net_a这一压缩包中的ASP.NET源码...

    计算机组成原理考点总结终结版.doc

    - 系统软件,如操作系统、语言处理程序、数据库管理系统等,负责管理和优化系统运行。 - 应用软件是用户根据特定需求编写的程序,如办公软件、图像处理软件等。 6. **计算机工作过程** - 运算器包含累加器、乘商...

    LearnSite1.092(无Flash上传控件终结版)2011.4.25.rar

    学生签到:可以了解每节课学生到场情况 特别是网页制作学习:内置与ftp相连数据库,每个学生账号不同,学生上传网页后,其他同学都可以浏览评价 打字练习,特别是拼音提示,对于部分汉字认识但不会拼音的学生也是一...

    计算机组成原理考点总结终结版.pdf

    1. **第一台计算机ENIAC**:ENIAC是电子数字积分计算机的简称,标志着计算机时代的开始。它庞大且笨重,主要用于科学计算。 2. **诺依曼体系结构**:由约翰·冯·诺依曼提出的,存储程序的概念是其核心,数据和程序...

    管理信息系统大作业终结版 (2).pdf

    在信息时代,借助科技手段可以有效提高管理效率,减少人为错误,快速响应客户需求。HMIS应具备易用性,选用Microsoft SQL Server作为数据库,以支持数据的稳定存储和高效处理。 【存在的问题】 1. 应用意识薄弱:...

    CrimeBustersAndroid:犯罪终结者的 Android 应用

    在数字化时代,移动应用已经成为我们日常生活的重要组成部分,尤其是在公共安全领域。"犯罪终结者Android"是一款基于Java开发的Android应用,旨在利用技术手段帮助预防和打击犯罪,提高社区的安全水平。下面,我们将...

    ODBC-API开发教程

    - **ODBC的历史背景**:ODBC的出现解决了不同数据库之间开发标准不一致的问题,它终结了所谓的“第二黑暗时代”——即没有统一标准的数据库开发时期。在ODBC出现之前,每个数据库厂商都有自己的开发包,这导致开发者...

    计算机组成原理考点总结终结版汇总.pdf

    - 第一台电子计算机ENIAC(Electronic Numerical Integrator And Computer),标志着计算机时代的开始。 - 冯·诺依曼(John von Neumann)提出的存储程序概念,奠定了现代计算机的基础。他的理论允许数据和程序...

    hstore

    “One Size Fits All”时代的终结 论文首先指出,过去被视为万能解决方案的传统RDBMS已无法满足当今多样化的需求。随着技术的发展,特别是硬件性能的飞跃,如处理器速度提升数千倍,内存容量扩大数千倍,这些老化...

    财务软件的三项新要素.doc

    这些要素标志着财务软件的革新,预示着传统财务软件时代的终结。 首先,网络化管理是新时代财务软件的基础。在当前全球化、信息化的背景下,企业需要实时掌握各地分部的财务状况,实现远程监控。财务软件必须具备...

    基于WCF Web数据挖掘的考试系统的实现.pdf

    随着WWW网络的不断壮大,各高校进入了网络化时代,教育和教学活动中不可或缺的一个环节就是考试。但是,传统的在线考试系统存在诸多问题,如题库数据重复性比重比较大、考试题库的传统性即只实现了单选、多选两种...

    从大数据角度分析通信网络监控体系的设计.docx

    把客户感知度作为出发点和终结点的网络监控体系不仅改善了传统的通信网络监控设计的不足,也能够快速的发现问题,及时派单,迅速修复,满足了随时随地的客户感知,适应了时代对移动通信行业的发展需求,提高了网络...

Global site tag (gtag.js) - Google Analytics