首页 > 图书中心 >图书详情
数据库设计及其应用程序开发
作者:周汉平
丛书名:高等学校教材·计算机科学与技术
定价:36元
印次:1-1
ISBN:9787302215257
出版日期:2010.01.01
印刷日期:2010.01.07
本书从关系型数据库模型设计、数据库服务器端SQL程序设计和数据库客户端程序设计三个方面介绍数据库设计及其应用程序开发的实用技术。第一部分介绍范式理论的运用和如何使用PowerDesigner依据需求建立正确合理的概念模型;第二部分介绍如何进行SQL程序设计以解决典型的应用问题;第三部分介绍使用Delphi、C# for .Net以及采用J2EE架构,进行C/S和B/S多层结构的数据库应用程序开发的基本方法。 本书可作为大学计算机本科专业的教材和计算机软件开发人员进行数据库设计和SQL程序设计的实用指导书,也可作为使用Delphi、C# for .Net和J2EE平台和架构开发数据库客户端和中间层应用程序的程序员入门参考书。
more >20世纪90年代初,我独立承接了一个期货交易所会员单位的保证金和交易管理系统的开发项目,那时不懂什么是数据库,更不懂数据库理论,但就凭着对计算机技术的浓厚兴趣,硬是夜以继日地把该项目做了下来,并得到了用户单位的好评。此后就一发不可收拾,十几年中独立开发或参与开发了很多大大小小的数据库应用系统,但对数据库理论的学习和研究却是几年以后的事了,其一是因为项目的开发越来越规范,尤其团队开发的情况下,各人的数据库设计方法各不相同,仅凭经验很难说服别人遵从自己的设计,那时也确实没有办法系统地论证某一种设计的优越性,所以迫切需要用理论知识来武装自己;其二是因为教学上的需要,我必须为计算机本科专业的学生开设“数据库系统概论”课程。 在学习数据库理论的过程中,发现最大的问题是理论和实践的脱节,过去软件设计过程中的疑难问题一一闪现,但很难在书上找到答案或从书上的实例中受到启发,原因是大多数数据库理论书籍告诉我们的是“理论是什么”,而很少告诉我们“为什么”或“怎么用”的问题,书中的实例也侧重于说明怎么做才符合理论,而没有告诉我们怎么用理论去指导设计和解决实际开发中的问题。 其次,目前关系型数据库理论已成体系,但其中只有一小部分内容对软件开发有实际意义,而大多数内容是从事数据库理论研究的人员所必须具备的知识,这是大学生在工作后,从事数据库应用系统的设计开发过程中,普遍感到在校学习的数据库理论没有用的主要而真实的原因所在。 此后学校又安排我开设“数据库应用程序设计”课程,我以为终于找到了把数据库理论和我所掌握的实践技能结合起来传授给学生的机会了,于是我开始找教材,目标很明确:教材要包含设计和开发数据库应用系统的所有实用的知识和技能,包括能直接指导数据库设计的理论、方法和工具、侧重实践的数据库服务器端的程序开发与基于目前主流语言和平台的客户端应用程序开发技术,遗憾的是,我竟然没有找到一本这样的书籍。 即便把两本甚至三本书合起来作为教材,在理论和实践的结合方面仍然不能令人满意,一些书只讲理论,而另一些书只讲实践,造成这种现象的原因很简单,从事软件开发的人,很少有时间、精力或兴趣去从事理论研究和出版书籍,而有条件搞理论研究的人又很缺乏从业经验,一些人为了获取经验投身到软件开发的第一线,但很 少有人再回过来利用这些经验去搞理论研究,这就是我们国家软件行业理论与实践关系之现状。 于是只能根据选出的内容制作课件,同时编写上机实验指导,经过对该课程的多次的教学实践,不断调整和充实了课件内容,然后以课件内容为核心编写了本书。 本书所涉及的知识和技能是进行规范高效的数据库应用程序设计和开发所必需的,也是与计算机相关的技术应用型本科专业学生所必须具备的。本书的最大特点是与应用的紧密结合,阐述理论和技术的重点不在于解决“是什么”的问题,而在于“怎么用”和“如何用更好”的问题,着力使读者能对具体问题的分析能力上有所提高。 第一部分包含了实用的数据库设计所要用到的理论、技术和工具,阐述了数据库的理论怎样在实践中得以应用又反过来证实和充实了理论,解析了实践中的一些典型案例,比较和分析了各种常见的设计方法的特点和在性能、效率上的优劣。第二部分包含了各种数据库服务器端的程序开发技术,重点讨论各种技术的特点和应用场合,讨论实现一个需求使用何种技术更好的问题,也包含了如何在实践中充分挖掘某种技术的功能,用简单的方法实现复杂的算法,其中用实例对SQL和核心语句SELECT应用技巧方面进行了深入和独特的介绍。第三部分使读者在选择应用系统结构时,对相关技术在短期内有一个直观的具体的了解,而在选定了某个系统结构后,能使读者对相关技术快速入门。所有的实例解析都是作者在软件行业长期从事数据库应用系统设计和开发过程中所探索的知识和经验的积累,具有典型性和一定的深度。 归纳起来,本书的主要特色体现在: * 理论和概念部分的解析以实际的应用问题为背景,以提出问题、分析问题,然后解决问题为主线。 * 在概念和功能上不求面面俱到,重点放在对实践应用中的实用、常用技术方法的分析上,包括同一应用问题不同处理方法的分析和比较。 * 对某些理论、概念以及和实践结合上存在的认识上的分歧和误区进行了分析,并给出了最终的结论。如对1NF进行深入而全面的剖析,指出了国内很多书籍和文章对1NF认识上的误区和局限性,从实践角度论证1NF的重要意义。 * 用实例比较全面地阐述范式与冗余的关系。 * 使用数据库的建模工具PowerDesigner,结合实例说明如何建立正确的概念数据模型以及建立正确的概念数据模型的重要性,详细阐述概念数据模型与其产生的物理数据模型的关系。 * 包含作者长期从事数据库软件开发过程中所积累的SQL语言尤其是SELECT语句独特的应用技巧的分析和介绍。 * 对复杂问题承上启下,问题的难度循序渐进,并且力求前后关联,逐步展开,最终对一个问题构成一个比较完整的解决方案。 * 通过实例介绍使用Delphi和C# for .Net的开发技术,结合实例对其数据库访问技术进行了深入浅出的剖析。 * 使用BEA Weblogic和Eclipse,以最简单的方式帮助读者跨过J2EE技术的门槛。 读者只需要具备计算机以及编程的基础知识,对实际应用问题具备一定的理解能力就可通读本书并由此获益,如果对面向对象程序设计的思想具有一定的了解,学习并理解了一定的数据库的理论知识并具备一定的软件开发经验,相信一定能从中获益。如果按部就班地按书上的指导完成具有实战价值的实例,并体会其中的技术思想,更可以把这些实践积累作为今后理解和掌握计算机领域其他知识的应用背景。经过近20年的软件设计、开发和研究,作者深刻地认识到,具备一定的应用背景是理解和掌握计算机软件开发技术非常重要的条件和途径。 本书由上海市第二工业大学周汉平编著,尽管书中所有内容经过作者的反复斟酌和论证测试,但错误在所难免,欢迎读者批评指正。 编 者 2009年8月于上海
more >