数据库时代的终结

原创 2006年06月24日 08:29:00

板桥里人 http://www.jdon.com 2005/04/28

  以数据库为核心的软件时代已经过去,数据库时代早已结束,当我看到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

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

有限状态机时代终结的10大理由

有限状态机时代终结的10大理由作者:alexjc译者:赖勇浩(恋花蝶)原文地址:http://aigamedev.com/questions/fsm-age-is-over本文最初发表于恋花蝶的博客(...
  • lanphaday
  • lanphaday
  • 2008年01月28日 22:40
  • 25350

数据库时代的终结

 这是一个实战中非常重要但是容易被忽视的概念,说它重要,是因为它比数据库重要;说它容易被忽视也是同样的原因,它经常被数据库概念替代。  如果你经验和经历中没有状态这个概念,极端地说:可能你的Java系...
  • cxzhq2002
  • cxzhq2002
  • 2006年11月08日 21:16
  • 636

数据库时代的终结

数据库时代的终结      板桥里人 http://www.jdon.com 2005/04/28      以数据库为核心的软件时代已经过去,数据库时代早已结束,当我看到J2EE征途中那么多人在对象...
  • 978107
  • 978107
  • 2005年09月13日 15:12
  • 568

数据库时代的终结(转)

  以数据库为核心的软件时代已经过去,数据库时代早已结束,当我看到J2EE征途中那么多人在对象和数据库之间彷徨痛苦ing的时候,我想我该出来喊一声了。  其实这句话在几年前肯定有人喊过,因为中间件时代...
  • chensheng913
  • chensheng913
  • 2005年05月20日 17:31
  • 6289

数据库时代的终结(转载)

数据库时代的终结板桥里人 http://www.jdon.com 2005/04/28  以数据库为核心的软件时代已经过去,数据库时代早已结束,当我看到J2EE征途中那么多人在对象和数据库之间彷徨痛苦...
  • Jack_yz79845
  • Jack_yz79845
  • 2006年05月07日 16:25
  • 606

用行为树与状态机写AI

对于有限状态机而言,必须明确 状态的转换方式;对于行为树,必须明确状态前提:前提条件 每一个行为必须有“前提条件” ,这决定了该行为是否被选择。 行为树的运算也是通过帧循环的update来驱动,不...
  • q49435962qqqqqqq
  • q49435962qqqqqqq
  • 2015年08月06日 09:20
  • 586

数据库时代的终结意味着什么?

说实话,作为一名想在数据库此领域长期发展的DBA,听到这种声音很吃惊,当然也不能苟同。 以数据库为核心的软件时代已经过去,数据库时代早已结束,当我看到J2EE征途中那么多人在对象和数据库之间彷徨痛苦i...
  • Jackenewq
  • Jackenewq
  • 2007年01月11日 11:03
  • 814

Winamp时代的终结

今天突然想起以前经常用的Winamp,因为在kugoo中可以用它的DFX的插件。就去搜一个Winamp来用,无意间看到了这么一篇文章,有点年头了,〔“霸王别姬”:悲叹Winamp时代的终结〕真是可惜了...
  • huicer
  • huicer
  • 2008年01月18日 10:08
  • 298

[文摘20071102]数据库时代的终结

本文转自:http://www.jdon.com/artichect/dbover.htm以数据库为核心的软件时代已经过去,数据库时代早已结束,当我看到J2EE征途中那么多人在对象和数据库之间彷徨...
  • freeliver54
  • freeliver54
  • 2007年11月02日 15:58
  • 140

云时代的终结

我们正面临云时代的终结,这是一个很大胆的论调,甚至有一些疯狂,但请耐心看完下面的内容。 传统的认知认为服务器应用的未来在云端。亚马逊、谷歌和微软在他们的云产品中加入越来越多的工具,让运行服务器软...
  • petpig0312
  • petpig0312
  • 2017年11月20日 21:17
  • 69
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:数据库时代的终结
举报原因:
原因补充:

(最多只允许输入30个字)