
在delphi中有一批数据库专用的控件,比如ADO类的,可以直接用于数据库开发,你可以先用一个Access数据库自己进行一下测试。
首先在窗体上放一个ADOConnection1控制,用于与Access数据库进行连接,连接字符串为:
ADOConnection1ADOC_DataConnectionString:='provider=MicrosoftJetOLEDB40;'
+'userID=Admin;'
//+'DataSource='+ExtractFilePath(ApplicationExeName)+'MyRecordmdb;'
+'DataSource='+MyDataBaseName+';'
+'Mode=ShareDenyNone;ExtendedProperties=\"\";'
+'JetOLEDB:Systemdatabase=\"\";'
+'JetOLEDB:RegistryPath=\"\";'
+'JetOLEDB:DatabasePassword=\"123456;'//数据库密码
+'JetOLEDB:EngineType=5;'
+'JetOLEDB:DatabaseLockingMode=1;'
+'JetOLEDB:GlobalPartialBulkOps=2;'
+'JetOLEDB:GlobalBulkTransactions=1;'
+'JetOLEDB:NewDatabasePassword=\"\";'
+'JetOLEDB:CreateSystemDatabase=False;'
+'JetOLEDB:EncryptDatabase=False;'
+'JetOLEDB:Don'+''''+'tCopyLocaleonCompact=False;'
+'JetOLEDB:CompactWithoutReplicaRepair=False;'
+'JetOLEDB:SFP=False';
DMADOC_DataLoginPrompt:=False;
再放一个ADOQuery1控制,用于 *** 作数据表,将它的Connection属性设置为ADOConnection1。或用语句实现:ADOQuery1Connection:=ADOConnection1;
然后再分别放置一个DataSource1和一个DBGrid1控件,
将DataSource1的DataSet属性设置为ADOQuery1。
将DBGrid1的DataSource属性设置为DataSource1。
这时就可以通过ADOQuery1来执行SQL语句来查询数据表,并通过DBGrid1显示出来了。
数据库系统概述
数据库系统为我们提供了一种把与我们的工作和生活紧密相关的信息集合在一起的方法 它还提供了在某个集中的地方存储和维护这些信息的方法 数据库系统主要由三大部分组成 数据库管理系统(DBMS:它是专门负责组织和管理数据信息的程序) 数据库应用程序(它使我们能够获取 显示和更新由DBMS存储的数据) 数据库(按一定结构组织在一起的相关数据的集合)
一般来说 DBMS和数据库应用程序都驻留在同一台计算机上并在同一台计算机上运行 很多情况下两者甚至结合在同一个程序中 以前使用的大多数数据库系统都是用这种方法设计的 但是随着DBMS技术的发展 目前的数据库系统正向客户/服务器模式发展 客户/服务器数据库将DBMS和数据库应用程序分开 从而提高了数据库系统的处理能力 数据库应用程序运行在一个或多个用户工作站(客户机)上 并且通过网络与运行在其它计算机上(服务器)的一个或多个DBMS进行通信
下面是数据库系统中一些概念和述语
数据库管理系统(DBMS)
数据库管理系统(DBMS)是用于描述 管理和维护数据库的程序系统 是数据库系统的核心组成部分 它建立在 *** 作系统的基础上 对数据库进行统一的管理和控制 其主要功能有
描述数据库 描述数据库的逻辑结构 存储结构 语义信息和保密要求等
管理数据库 控制整个数据库系统的运行 控制用户的并发性访问 检验数据的安全 保密与完整性 执行数据检索 插入 删除 修改等 *** 作
维护数据库 控制数据库初始数据的装入 记录工作日志 监视数据库性能 修改更新数据库 重新组织数据库 恢复出现故障的数据库
数据通信 :组织数据的传输
DBMS主要有四种类型 文件管理系统 层次数据库系统 网状数据库系统和关系数据库系统 因为目前关系数据库系统应用最为广泛 所以我们重点对关系数据库系统中的几个概念进行介绍
关系数据库(Relational Database) 一个关系数据库是由若干表组成 在Delphi中 数据库概念对应到物理文件上是有一些不同的 对于dBASE FoxPro Paradox这三种数据库系统 数据库对应于某一个子目录 而其它类型如MS Access Btrieve则是指某个文件 这是因为前者的表为单独的文件 而后者的表是聚集在一个数据库文件中的
表(Table) 一个表就是一组相关的数据按行排列 象一张表格一样 比如一个班所有学生的期末考试成绩 存在一个表中 每一行对应一名学生 在这一行中 包括学生的学号 姓名以及各门课程的成绩
字段(Field) 在表中 每一列称为一个字段 每一个字段都有相应的描述信息 如数据类型 数据宽度等
记录(Record) 在表中 每一行称为一条记录
索引(Index) 为了加快访问数据库的速度 许多数据库都使用索引
数据库应用程序
DBMS中存储了大量的数据信息 其目的是为用户提供数据信息服务 而数据库应用程序正是与DBMS进行通信 并访问DBMS中的数据 它是DBMS实现其对外提供数据信息服务这一目的的唯一途径 简单地说 数据库应用程序是一个允许用户插入 修改 删除并报告数据库中的数据的计算机程序 数据库应用程序在传统上是由程序员用一种或多种通用或专用的程序设计语言编写的 但是近年来出现了多种面向用户的数据库应用程序开发工具 这些工具可以简化使用DBMS的过程 并且不需要专门编程 Delphi就是一种强有力的数据库应用程序开发工具
用来生成数据库应用程序的语言主要分为三大类型
过程化语言
标准的计算机程序设计语言如Pascal Basic和C都是过程化语言 这些语言可以通过某种 应用程序接口 (API)来创建数据库应用程序 这种API由一组标准的函数(或调用)组成 这些函数和调用则扩展了语言的功能 使之能访问数据库中的数据 当程序设计人员用过程化语言创建数据库应用时 必须把应用的代码编写成一系列的过程 每个过程执行应用的某一部分的工作 如一个过程查询数据库 而另一过程更新数据库中的数据 然后不同的过程通过其他的用户界面过程(例如菜单系统)联系在一起 并且在应用中的适当地方运行
上述这些过程化语言一般用来创建非数据库应用程序 它们通常被称为 第三代语言 ( GL) 还有一些过程化程序设计语言是某种特定的DBMS专用的 这些语言一般被称为 第四代语言 ( GL) 即数据库专用语言 常见的数据库专用的过程化语言如dBASE语言 Paradox数据库的PAL语言等等
结构化查询语言(SQL)
结构化查询语言(Structure Query Language)是基于关系模型的数据库查询语言 它是一种非过程化的程序语言 也就是说 没有必要写出将如何做某事情 只需写出做到什么就可以了 写出的语句可看作是一个问题 称为 查询 (Query) 针对这个查询 得到所需的查询结果 下面是一个例子
Select Name Total from Class where Total>
这个查询意为从数据库表Class中将总分(Total)大于 的所有人选出来 并列出他们的姓名(Name)和总分(Total)
把SQL描述为子语言更适当一些 因为它没有任何屏幕处理或用户输入/输出的能力 它的主要目的是为了提供访问数据库的标准方法 而不管数据库应用的其余部分是用什么语言编写的 它既是为数据库的交互式查询而设计的(因此被称为动态SQL) 同时也可在过程化语言编写的数据库应用程序中使用(因此被称为嵌入式SQL)
lishixinzhi/Article/program/Delphi/201311/25182
计算机语言的种类非常的多,总的来说可以分成机器语言,汇编语言,高级语言三大类。
电脑每做的一次动作,一个步骤,都是按照以经用计算机语言编好的程序来执行的,程序是计算机要执行的指令的集合,而程序全部都是用我们所掌握的语言来编写的。所以人们要控制计算机一定要通过计算机语言向计算机发出命令。
计算机所能识别的语言只有机器语言,即由0和1构成的代码。但通常人们编程时,不采用机器语言,因为它非常难于记忆和识别。
目前通用的编程语言有两种形式:汇编语言和高级语言。
汇编语言的实质和机器语言是相同的,都是直接对硬件 *** 作,只不过指令采用了英文缩写的标识符,更容易识别和记忆。它同样需要编程者将每一步具体的 *** 作用命令的形式写出来。汇编程序通常由三部分组成:指令、伪指令和宏指令。汇编程序的每一句指令只能对应实际 *** 作过程中的一个很细微的动作,例如移动、自增,因此汇编源程序一般比较冗长、复杂、容易出错,而且使用汇编语言编程需要有更多的计算机专业知识,但汇编语言的优点也是显而易见的,用汇编语言所能完成的 *** 作不是一般高级语言所能实现的,而且源程序经汇编生成的可执行文件不仅比较小,而且执行速度很快。
高级语言是目前绝大多数编程者的选择。和汇编语言相比,它不但将许多相关的机器指令合成为单条指令,并且去掉了与具体 *** 作有关但与完成工作无关的细节,例如使用堆栈、寄存器等,这样就大大简化了程序中的指令。同时,由于省略了很多细节,编程者也就不需要有太多的专业知识。
高级语言主要是相对于汇编语言而言,它并不是特指某一种具体的语言,而是包括了很多编程语言,如目前流行的VB、VC、FoxPro、Delphi等,这些语言的语法、命令格式都各不相同。
高级语言所编制的程序不能直接被计算机识别,必须经过转换才能被执行,按转换方式可将它们分为两类:
解释类:执行方式类似于我们日常生活中的“同声翻译”,应用程序源代码一边由相应语言的解释器“翻译”成目标代码(机器语言),一边执行,因此效率比较低,而且不能生成可独立执行的可执行文件,应用程序不能脱离其解释器,但这种方式比较灵活,可以动态地调整、修改应用程序。
编译类:编译是指在应用源程序执行之前,就将程序源代码“翻译”成目标代码(机器语言),因此其目标程序可以脱离其语言环境独立执行,使用比较方便、效率较高。但应用程序一旦需要修改,必须先修改源代码,再重新编译生成新的目标文件(*OBJ)才能执行,只有目标文件而没有源代码,修改很不方便。现在大多数的编程语言都是编译型的,例如VisualC++、VisualFoxpro、Delphi等。
学习编程,从何入手
如果您想学习编程,却又不知从何入手,那么您不妨看看下面的几种学习方案,可能会给您一些启示吧!
方案一Basic语言&VisualBasic
优点
(1)Basic简单易学,很容易上手。
(2)VisualBasic提供了强大的可视化编程能力,可以让你轻松地做出漂亮的程序。
(3)众多的控件让编程变得象垒积木一样简单。
(4)VisualBasic的全部汉化让我们这些见了English就头大的人喜不自禁。
缺点
(1)VisualBasic不是真正的面向对象的开发文具。
(2)VisualBasic的数据类型太少,而且不支持指针,这使得它的表达能力很有限。
(3)VisualBasic不是真正的编译型语言,它产生的最终代码不是可执行的,是一种伪代码。它需要一个动态链接库去解释执行,这使得VisualBasic的编译速度大大变慢。
综述:方案一适合初涉编程的朋友,它对学习者的要求不高,几乎每个人都可以在一个比较短的时间里学会vB编程,并用VB做出自己的作品。对于那些把编程当做游戏的朋友来说,VB是您最佳的选择。
方案二Pascal语言&Delphi
优点
(1)Pascal语言结构严谨,可以很好地培养一个人的编程思想。
(2)Delphi是一门真正的面向对象的开发工具,并且是完全的可视化。
(3)Delphi使用了真编译,可以让你的代码编译成为可执行的文件,而且编译速度非常快。
(4)Delphi具有强大的数据库开发能力,可以让你轻松地开发数据库。
缺点
Delphi几乎可以说是完美的,只是Pascal语言的过于严谨让人感觉有点烦。
综述:方案二比较适合那些具有一定编程基础并且学过Pascal语言的朋友。
方案三C语言&VisualC
优点
(1)C语言灵活性好,效率高,可以接触到软件开发比较底层的东西。
(2)微软的MFC库博大精深,学会它可以让随心所欲地进行编程。
(3)VC是微软制作的产品,与 *** 作系统的结合更加紧密。
缺点
对使用者的要求比较高,既要具备丰富的C语言编程经验,又要具有一定的WINDOWS编程基础,它的过于专业使得一般的编程爱好者学习起来会有不小的困难。
综述:VC是程序员用的东西。如果你是一个永不满足的人,而且可以在编程上投入很大的精力和时间,那么学习VC你一定不会后悔的。
C语言简介
方案四C语言&CBuilder
优点
(1)C语言的优点全部得以继承。
(2)完全的可是化。
(3)极强的兼容性,支持OWL、VCL和MFC三大类库。
(4)编译速度非常快。
缺点
由于推出的时间太短,关于它的各种资料还不太多。
综述:我认为CBuilder是最好的编程工具。它既保持了C语言编程的优点,又做到了完全的可视化。
方案五SQL语言&PowerBuilder
对于一些传统的数据开发人员来说,Foxpro系列也许让他们感到更加熟悉。但是对于初学者来说,也许是最好的数据库开发工具。各种各样的控件,功能强大的语言都会帮助你开发出自己的数据库应用程序。
JSP简介
在Sun正式发布JSP(JavaServerPages)之后,这种新的Web应用开发技术很快引起了人们的关注。JSP为创建高度动态的Web应用提供了一个独特的开发环境。按照Sun的说法,JSP能够适应市场上包括ApacheWebServer、IIS40在内的85%的服务器产品。
JSP与ASP的简单比较
JSP与Microsoft的ASP技术非常相似。两者都提供在HTML代码中混合某种程序代码、由语言引擎解释执行程序代码的能力。在ASP或JSP环境下,HTML代码主要负责描述信息的显示样式,而程序代码则用来描述处理逻辑。普通的HTML页面只依赖于Web服务器,而ASP和JSP页面需要附加的语言引擎分析和执行程序代码。程序代码的执行结果被重新嵌入到HTML代码中,然后一起发送给浏览器。ASP和JSP都是面向Web服务器的技术,客户端浏览器不需要任何附加的软件支持。
ASP的编程语言是VBScript之类的脚本语言,JSP使用的是Java,这是两者最明显的区别。
此外,ASP与JSP还有一个更为本质的区别:两种语言引擎用完全不同的方式处理页面中嵌入的程序代码。在ASP下,VBScript代码被ASP引擎解释执行;在JSP下,代码被编译成Servlet并由Java虚拟机执行,这种编译 *** 作仅在对JSP页面的第一次请求时发生。
运行环境
执行JSP代码需要在服务器上安装JSP引擎。此处我们使用的是Sun的JavaServerWebDevelopmentKit(JSWDK)。为便于学习,这个软件包提供了大量可供修改的示例。安装JSWDK之后,只需执行startserver命令即可启动服务器。在默认配置下服务器在端口8080监听,使用localhost:8080即可打开缺省页面。
在运行JSP示例页面之前,请注意一下安装JSWDK的目录,特别是"work"子目录下的内容。执行示例页面时,可以在这里看到JSP页面如何被转换成Java源文件,然后又被编译成class文件(即Servlet)。JSWDK软件包中的示例页面分为两类,它们或者是JSP文件,或者是包含一个表单的HTML文件,这些表单均由JSP代码处理。与ASP一样,JSP中的Java代码均在服务器端执行。因此,在浏览器中使用"查看源文件"菜单是无法看到JSP源代码的,只能看到结果HTML代码。所有示例的源代码均通过一个单独的"examples"页面提供。
JavaServlet是一种开发Web应用的理想构架。JSP以Servlet技术为基础,又在许多方面作了改进。JSP页面看起来象普通HTML页面,但它允许嵌入执行代码,在这一点上,它和ASP技术非常相似。利用跨平台运行的JavaBean组件,JSP为分离处理逻辑与显示样式提供了卓越的解决方案。JSP必将成为ASP技术的有力竞争者。
SQL语言简介
SQL全称是“结构化查询语言(StructuredQueryLanguage)”,最早的是IBM的圣约瑟研究实验室为其关系数据库管理系统SYSTEMR开发的一种查询语言,它的前身是SQUARE语言。SQL语言结构简洁,功能强大,简单易学,所以自从IBM公司1981年推出以来,SQL语言,得到了广泛的应用。如今无论是像Oracle,Sybase,Informix,SQLserver这些大型的数据库管理系统,还是像VisualFoxporo,这些微机上常用的数据库开发系统,都支持SQL语言作为查询语言。
StructuredQueryLanguage包含4个部分:
数据查询语言DQL-DataQueryLanguageSELECT
数据 *** 纵语言DQL-DataLanguageINSERT,UPDATE,DELETE
数据定义语言DQL-DataDefinitionLanguageCREATE,ALTER,DROP
数据控制语言DQL-DataControlLanguageCOMMITWORK,ROLLBACKWORK
SQL的历史
在70年代初,EECodd首先提出了关系模型。70年代中期,IBM公司在研制SYSTEMR关系数据库管理系统中研制了SQL语言,最早的SQL语言(叫SEQUEL2)是在1976年11月的IBMJournalofR&D上公布的。
SQL的优点
SQL广泛地被采用正说明了它的优点。它使全部用户,包括应用程序员、DBA管理员和终端用户受益非浅。
(1)非过程化语言
SQL是一个非过程化的语言,因为它一次处理一个记录,对数据提供自动导航。SQL允许用户在高层的数据结构上工作,而不对单个记录进行 *** 作,可 *** 作记录集。所有SQL语句接受集合作为输入,返回集合作为输出。SQL的集合特性允许一条SQL语句的结果作为另一条SQL语句的输入。SQL不要求用户指定对数据的存放方法。这种特性使用户更易集中精力于要得到的结果。所有SQL语句使用查询优化器,它是RDBMS的一部分,由它决定对指定数据存取的最快速度的手段。查询优化器知道存在什么索引,哪儿使用合适,而用户从不需要知道表是否有索引,表有什么类型的索引。
(2)统一的语言
SQL可用于所有用户的DB活动模型,包括系统管理员、数据库管理员、应用程序员、决策支持系统人员及许多其它类型的终端用户。基本的SQL命令只需很少时间就能学会,最高级的命令在几天内便可掌握。SQL为许多任务提供了命令,包括:
查询数据
在表中插入、修改和删除记录
建立、修改和删除数据对象
控制对数据和数据对象的存取
保证数据库一致性和完整性
以前的数据库管理系统为上述各类 *** 作提供单独的语言,而SQL将全部任务统一在一种语言中。
(3)是所有关系数据库的公共语言
由于所有主要的关系数据库管理系统都支持SQL语言,用户可将使用SQL的技能从一个RDBMS转到另一个。所有用SQL编写的程序都是可以移植的。
Java语言简介
一Java的由来
当1995年SUN推出Java语言之后,全世界的目光都被这个神奇的语言所吸引。那么Java到底有何神奇之处呢
Java语言其实最是诞生于1991年,起初被称为OAK语言,是SUN公司为一些消费性电子产品而设计的一个通用环境。他们最初的目的只是为了开发一种独立于平台的软件技术,而且在网络出现之前,OAK可以说是默默无闻,甚至差点夭折。但是,网络的出现改变了OAK的命运。
在Java出现以前。Internet上的信息内容都是一些乏味死板的HTML文档。这对于那些迷恋于WEB浏览的人们来说简直不可容忍。他们迫切希望能在WEN中看到一些交互式的内容,开发人员也极希望能够在WEB上创建一类无需考虑软硬件平台就可以执行的应用程序,当然这些程序还要有极大的安全保障。对于用户的这种要求,传统的编程语言显得无能为力,面SUN的工程师敏锐地察觉到了这一点,从1994年起,他们开始将OAK技术应用于WEB上,并且开发出了HotJava的第一个版本。当SUN公司1995年正式以Java这个名字推出的时候,几乎所有的WEB开发人员都想到:噢,这正是我想要的。于是Java成了一颗耀眼的明星,丑小鸭一下了变成了白天鹅。
二Java的定义
Java是一种简单的,面象对象的,分布式的,解释的,键壮的安全的,结构的中立的,可移植的,性能很优异的多线程的,动态的语言。
Java的开发环境有不同的版本,如sun公司的JavaDevelopersKit,简称JDK。后来微软公司推出了支持Java规范的MicrosoftVisualJJava开发环境,简称VJ。
三Java的特点
1平台无关性
平台无关性是指Java能运行于不同的平台。Java引进虚拟机原理,并运行于虚拟机,实现不同平台的Java接口之间。使用Java编写的程序能在世界范围内共享。Java的数据类型与机器无关,Java虚拟机(JavaVirtualMachine)是建立在硬件和 *** 作系统之上,实现Java二进制代码的解释执行功能,提供于不同平台的接口的。
2安全性
Java的编程类似C,学习过C的读者将很快掌握Java的精髓。Java舍弃了C的指针对存储器地址的直接 *** 作,程序运行时,内存由 *** 作系统分配,这样可以避免病毒通过指针侵入系统。Java对程序提供了安全管理器,防止程序的非法访问。
3面向对象
Java吸取了C面向对象的概念,将数据封装于类中,利用类的优点,实现了程序的简洁性和便于维护性。类的封装性、继承性等有关对象的特性,使程序代码只需一次编译,然后通过上述特性反复利用。程序员只需把主要精力用在类和接口的设计和应用上。Java提供了众多的一般对象的类,通过继承即可使用父类的方法。在Java中,类的继承关系是单一的非多重的,一个子类只有一个父类,子类的父类又有一个父类。Java提供的Object类及其子类的继承关系如同一棵倒立的树形,根类为Object类,Object类功能强大,经常会使用到它及其它派生的子类。
4分布式
Java建立在扩展TCP/IP网络平台上。库函数提供了用>
5键壮性
Java致力于检查程序在编译和运行时的错误。类型检查帮助检查出许多开发早期出现的错误。Java自已 *** 纵内存减少了内存出错的可能性。Java还实现了真数组,避免了覆盖数据的可能。这些功能特征大大提高了开发Java应用程序的周期。Java提供:Null指针检测、数组边界检测、异常出口、Bytecode校验。
四Java与C/C语言
Java提供了一个功能强大语言的所有功能,但几乎没有一点含混特征。C安全性不好,但C和C被大家接受,所以Java设计成C形式,让大家很容易学习。
Java去掉了C语言的许多功能,让Java的语言功能很精炼,并增加了一些很有用的功能,如自动收集碎片。
Java去掉了以下几个C和C功能:
指针运算
结构
typedefs
#define
需要释放内存
这将减少了平常出错的50%。而且,Java很小,整个解释器只需215K的RAM。
面象对象:Java实现了C的基本面象对象技术并有一些增强,(为了语言简单,删除了一些功能)。Java处理数据方式和用对象接口处理对象数据方式一样。
五Java与Internet
我们知道,早先的>
Java并不是为Internet,>
Java程序和它的浏览器HotJava,提供了可让你的浏览器运行程序的方法。你能从你的浏览器里直接播放声音。你还能播放页面里的动画。Java还能告诉你的浏览器怎样处理新的类型文件。当我们能在2400baud线上传输视频图象时,HotJava将能显示这些视频。
当今Internet的一大发展趋势是电子商务,而Internet的安全问题是必须解决的问题,通常大的部门应设置防火墙,阻止非法侵入。
电子商务是当今的热门话题,然而传统的编程语言难以胜任电子商务系统,电子商务要求程序代码具有基本的要求:安全、可靠、同时要求能与运行于不同平台的机器的全世界客户开展业务。Java以其强安全性、平台无关性、硬件结构无关性、语言简洁同时面向对象,在网络编程语言中占据无可比拟的优势,成为实现电子商务系统的首选语言。
Java程序被放置在Internet服务器上,当用户访问服务器时,Java程序被下载到本地的用户机上,由浏览器解释运行。
Delphi简介
Delphi这个名字源于古希腊的城市名。它集中了第三代语言的优点。以ObjectPascal为基础,扩充了面向对象的能力,并且完美地结合了可视化的开发手段。Delphi自1995年3月一推出就受到了人们的关注,并在当年一举夺得了多项大奖。
Delphi的出现打破了V承可视化编程领域一统天下的局面。并且Delphi使用了本地编译器直接生成技术,使程序的执行性能远远高于其它产品生成的程序。它还是真正的面向对象的编程语言。PASCAL语言的严谨加上可视化的优势和强大的数据库功能使得它有充分的资本和微软的VB叫板。许多人当时都认为Pascal是最有前途的程序设计语言,并预测Delphi将会成为可视化编程的主流环境。
Delphi在你编好程序后自动转换成EXE文件它运行时速度比VB快,而且编译后不需要其他的支持库就能运行。它的数据库功能也挺强的,是开发中型数据库软件理想的编程工具。Delphi适用于应用软件、数据库系统、系统软件等类型的开发。而且它拥有和VB差不多一样的功能,而且一样能应用API函数,这在控制Windows很有用。
Delphi是全新的可视化编程环境,为我们提供了一种方便、快捷的Windows应用程序开发工具。它使用了MicrosoftWindows图形用户界面的许多先进特性和设计思想,采用了d性可重复利用的完整的面向对象程序语言(Object-OrientedLanguage)、当今世界上最快的编辑器、最为领先的数据库技术。对于广大的程序开发人员来讲,使用Delphi开发应用软件,无疑会大大地提高编程效率,而且随着应用的深入,您将会发现编程不再是枯燥无味的工作——Delphi的每一个设计细节,都将带给您一份欣喜。
Delphi的基本形式
Delphi实际上是Pascal语言的一种版本,但它与传统的Pascal语言有天壤之别。一个Delphi程序首先是应用程序框架,而这一框架正是应用程序的“骨架”。在骨架上即使没有附着任何东西,仍可以严格地按照设计运行。您的工作只是在“骨架”中加入您的程序。缺省的应用程序是一个空白的窗体(form),您可以运行它,结果得到一个空白的窗口。这个窗口具有Windows窗口的全部性质:可以被放大缩小、移动、最大最小化等,但您却没有编写一行程序。因此,可以说应用程序框架通过提供所有应用程序共有的东西,为用户应用程序的开发打下了良好的基础。
Delphi已经为您做好了一切基础工作——程序框架就是一个已经完成的可运行应用程序,只是不处理任何事情。您所需要做的,只是在程序中加入完成您所需功能的代码而已。在空白窗口的背后,应用程序的框架正在等待用户的输入。由于您并未告诉它接收到用户输入后作何反应,窗口除了响应Windows的基本 *** 作(移动、缩放等)外,它只是接受用户的输入,然后再忽略。
一 概述Delphi作为Windows下的一种快速开发工具 不仅能开发一般的Windows应用程序 而且还具有强大的数据库应用程序开发功能 Delphi本身提供了对BDE ODBC ADO和InterBase几种数据库驱动的支持 能够满足不同应用对数据库程序开发的需要 然而 在发布用Delphi开发的数据库程序时 除了要安装应用程序之外 还需要同时发布数据库驱动程序 这对于一些只涉及单个或多个简单表数据存储的单机应用程序来说 就显得有点头重脚轻的感觉了 况且 有些应用程序本身需要存储大量数据 但本身又要求结果短小精悍的话 用Delphi常规开发数据库的方法就不能满足需要了 那么 有没有办法解决上述矛盾 开发出能脱离庞大的数据库驱动程序的 瘦 数据库单机应用程序呢?Delphi 在Midas控件面板中提供了一个TClientDataSet控件 可以很好地解决这个问题 二 TClientDataSet使用要点TClientDataSet控件继承自TDataSet 其数据存储文件格式扩展名为 cds 是基于文件型数据存储和 *** 作的控件 该控件封装了对数据进行 *** 作处理的接口和功能 而本身并不依赖上述几种数据库驱动程序 基本上能满足单机 瘦 数据库应用程序的需要 .TClientDataSet的基本属性和方法介绍 ).FieldDefs: 字段定义列表属性开发者可通过单击属性编辑器中该属性编辑按钮 或在该控件上单击右键选择d出菜单中的 Fields Editor 菜单进行字段编辑 设置完此属性后 实际上就相当于定义了表的结构 如果想装入已有的数据表的结构和数据 可通过单击右键选择d出菜单中的 Assign Local Data 菜单 从d出对话框中选取当前窗体中已与数据库连接好的数据集控件名称即可(当前窗体中必须已放置好要套用的数据集控件并打开激活) 使用注意 对于自定义的字段名表 该属性编辑完后 该控件仍然无法打开 必须右键单击该控件 选择d出菜单中的 Create DataSet 菜单 让该控件以上述编辑的字段列表为依据 创建数据集后 才能够被激活打开和使用 否则 会出现类似 ClientDataSet : Missing data provider or data packet 的错误(包括在运行期 运行期可调用该控件的CreateDataSet方法 从而动态定义字段和表) ).FileName属性说明 数据存储文件的名称 因该控件是基于文件型的数据 *** 作控件 因此 必须指定所 *** 作的数据文件名称(默认扩展名称 cds) 从而打开和激活该控件 进而进行数据编辑 例 利用此属性打开指定的 cds文件varPath: string;beginPath := ExtractFilePath(Application ExeName); //取得可执行文件路径CDataSet FileName := Path + test cds ;CDataSet Open;end; ).CreateDataSet方法说明 该方法以FieldDefs中的字段名表为结构建立数据集 常用来进行动态定义表 例 动态创建一具有姓名和年龄两个字段的数据集 //创建字段名表CDataSet FieldDefs Clear;with CDataSet FieldDefs AddFieldDef dobeginName := Name ;Size := ;DataType := ftString;end;with CDataSet FieldDefs AddFieldDef dobeginName := Age ;DataType := ftInteger;end;//动态创建数据集CDataSet CreateDataSet;//激活和打开该数据集CDataSet Open; ).Open方法说明 打开和激活数据集控件 从而进行数据编辑 a 如果指定了FileName属性 则直接用Open方法即可打开和激活该控件 见例 b 如果未指定FileName属性 可使用例 方法动态创建和打开数据集 进而 *** 作数据 ).LoadFromFile和SaveToFile说明 从文件中装入表结构和数据以及存储数据到文件 该方法类似于Word中的打开新文件和另存为的功能 例 :将数据集的数据存储到指定文件中CDataSet SaveToFile( c:\windows\desktop\test cds ); ) First(到首) Prior(向前) Next(向后) Last(到尾) Edit(编辑) CanCel(取消编辑) Post(保存) Insert(插入记录) Append(添加记录) Delete(删除) Refresh(数据刷新)等数据集常用方法说明 当指定了FileName属性时 其Post方法可将数据存入指定的文件中 类似其SaveToFile方法 如果未指定存储文件名 则Post方法只将数据存储在RAM中 其它方法 同一般数据集控件使用方法 略 ) Filter Filtered: 过滤筛选属性说明:用于筛选指定条件的记录 用法同一般数据集控件 略 例 在已经激活打开的数据集中筛选性别为男性的记录CDataSet Close;CDataSet Filter := 性别= + 男 + ;CDataSet Filtered := True;CDataSet Open; .使用TClientDataSet控件的应用程序发布的注意事项 如前所述 使用TClientDataSet控件的程序发布时不需要任何数据库驱动程序 大大节省了安装文件的大小 但是 在发布程序时别忘了将Windows系统目录下midas dll( KB)与应用程序一起发布(运行必须) 否则 程序仍然无法正常运行 三 结束语通过使用Delphi中TClientDataSet控件 既实现了应用程序可彻底脱离数据库驱动程序 也实现了常规数据集控件简单易用的特性 为编写 瘦 数据库应用程序提供了一种技术方法和手段 上述程序在Pwindows Delphi 下测试通过 lishixinzhi/Article/program/Delphi/201311/24702
数据库窗体专家和数据库 *** 作台(DBD)
Delphi为用户开发简单的数据库应用程序提供了一个开发工具叫做 数据库窗体专家 (Database Form Expert) 在Delphi系统菜单Tool菜单下可以找到
数据库窗体专家能够自动生成简单的数据库应用程序中所必须完成的许多任务 它还可以生成基于单个数据库表的应用程序窗体或基于主要──明细型多个数据库表的应用程序窗体 数据库窗体专家能够自动完成的任务如下
● 放置数据库部件到窗体中(TDataSource部件)
● 为数据集部件(TTable TQuery)和磁盘上的数据库建立连接
● 建立数据源(TDataSource)与数据控制部件的连接 数据源(TDataSource)与 数据访问部件(TTable TQuery)的连接
● 为TQuery部件编写SQL语句
● 为窗体中的部件定义Tab顺序
数据库 *** 作台(DBD)是数据库维护和数据定义工具 程序设计人员利用它可以查询 连接 建立 重构 索引 修改和拷贝数据库表 包括Pà€aradox和dBASE文件和基于 SQL语言的数据库表 而且在使用DBD *** 作Paradox或dBASE的表时 用户不必拥有 Paradox 或dBASE数据库管理系统 DBD还可以把一种格式的数据和数据字典拷贝成另一种格式 例如 你可以将一个dBASE的表拷贝到远程的SQL服务器上的一个数据库中去 有关DBD详细描述 请参看 数据库 *** 作台(DBD)的使用
Delphi数据库应用程序的开发方法和步骤
概述
用Derphi用开数据库应用程序 虽然与开发其他应用程序有相似之处 但是也有一些重要的区别 我们必须要加以注意
利用Delphi的客户/服务器功能 程序设计者可以在本地数据库上或远程数据库服务器上开发客户/服务器模式的应用程序 Delphi 的一个强有力的功能之一是可以将基于本地桌面数据库系统的应用程序很容易地修改成客户/服务器模式的应用 一个Delphi 数据库应用程序访问的是本地数据库还是远程SQL数据库服务器上的数据库 这对于最终用户是完全透明的 即数据库的物理位置对最终用户是透明的 当数据库的物理位置发生变化时 用户界面不必随之变化
因为数据库应用程序的是依赖于它所访问的数据库的 所以在开发数据库应用程序之前必须要建立一个完善的数据库即数据定义 数据定义应当是开发数据库应用程序的一部分 但它超出了书本的范围 有关数据定义的内容 请参看关系数据库设计方面的资料 在我们用Derphi开发一个数据库应用程序时 可能有下列四种情况
数据库不存在或者必须要重新定义 使用DBD为本地数据库定义Paradox或dBASE 数据库表 使用Delphi提供的服务器开发工具如Windows ISQL或DBD定义本地或远程SQL数据库务器上的数据库
数据库在桌面数据库系统中或局域网上(如Paradox或dBASE) 而且BDE 数据库和应用程序在同一台机器上 这是典型的独立应用
数据库在桌面数据库系统中 但是用户要把它改变到SQL数据库服务器中去 这种情况我们在附录C中详细讨论
数据库在SQL数据库服务器中 而且应用程序将到SQL数据库服务器中去访问数据库 这是一个标准的客户/服务器应用
有关开发客户/服务器应用程序的详细内容 参看 客户/服务器应用 一章
数据库应用程序的开发步骤
数据库应用程序的最终目标就是为用户提供一个满足其长期需要的软件产品 因此 成功地开发一个数据库应用程序的关键之一是要详细地定义用户的需求 然后再围绕用户的需求进行开发 数据库应用程序的一般开发的三个基本步骤如下
● 系统设计
● 系统实现
● 系统运行和维护
在这个三个基本步骤中 都包含着数据库的开发和应用程序界面的开发两大类任务 对于一个客户/服务器模式的应用 数据库和应用界面的区别就更明显一些 因为它们运行在不同的平台之上 而且使用的 *** 作系统都常常不一样 如(一个Unix环境的服务器和Windows环境的客户机)
系统设计
系统设计阶段应当根据用户的需求 明确地描述数据库(数据库服务器端)和应用界面(客户机端)实现的功能 即决定哪些功能由服务器端实现 哪些功能由客户机端实现 对于客户/服务器应用程序 许多功能既可以在服务器端实现又可以在客户端实现的 例如一个复杂的数学变换功能既可以由客户端的应用程序实现 也可以由服务器端的存贮过程实现 服务器和客户端应用程序功能的划分往往取决于应用程序运行的硬件环境 例如 如果客户端是低档的PC机 服务器端是高档的工作站 那么大量的计算由服务器完成是比较理想的
系统实现
系统实现阶段的主要任务是使用Delphi提供的工具和部件以及Pascal语言实现系统设计阶段的设想 并进行调试
在系统实现阶段 最好使用数据库的一个备份数据库 这个备份的数据库与原数据库具有相同的结构 但其中的数据库只是原数据库中的一部分 至所以不在原数据库上开发应用程序 是因为考虑到没有调试好的应用程序可能会破坏数据库中的数据或者妨碍数据库的正常 *** 作
如果应用程序是基于远程SQL数据库服务器的 在系统实现阶段可以采用两种方法
● 在本地InterBase服务器上 使用数据库的备份数据库进行开发和调试
● 在远程服务器上 使用数据库的备份数据库进行开发和调试
第一种方法优越性在于 它是独立于服务器的 而不至于影响服务器的其它的 *** 作 而且不消耗服务器的资源不增加网络的负担 它的不利的方面是开发出来的应用程序只能在标准的SQL服务器上使用和调试 第二种方法能够使程序设计人员直接感受到服务器的特性 但它在调试阶段要消耗网络和服务器的资源 这种方法具有一定的危险性 程序中的错误可能会导致服务器的瘫痪
系统运行和维护
一个应用系统性能的优劣 效率的高低始终应当由用户来做出判决 应用程序在运行过程中 用户会提出一些新的需求和建议 根据用户需求的变化 应当对应用程序做一定的修改 使其进一步地得到完善和提高
交付数据库应用程序
交付数据库应用程序意味着将它交付给最终用户 并且提供应用程序运行所需的软件 非数据库应用程序往往只需要一个EXE文件 而数据库应用程序要包括下列几类文件
● 数据库应用程序生成的EXE文件和DLL文件(如果有的话)
● 必要的辅助文件(如Readme文件或HLP联机帮助文件)
● 支持访问数据库的BDE 有时也称为IDAPI
● 用于打印输出报表的ReportSmith报表工具
● 如果应用中使用了VBX控件 还要包括VBX和BIVBXII DLL
安装BDE
在交付数据库应用程序时 必须同时在运行应用程序的机器上安装BDE Delphi 本身包含可再安装的BDE 在准备数据库应用程序安装盘时 同时从Delphi中复制一份BDE 到最终用户的机器中 BDE中包含访问多种数据库系统的驱动程序 为了节省磁盘空间 在安装BDE时 可以只安装应用程序必须的驱动程序 例如 如果我们的应用程序只需要访问dBASE数据库文件 那么在安装BDE时 只需安装dBASE的驱动程序就行了 要访问Paradox数据库 BDE至少需要 KB的磁盘空间 BDE主要包括下列文件 请参看DEPLOY TXT文件
lishixinzhi/Article/program/Delphi/201311/25177
以上就是关于新手如何delphi开发数据库全部的内容,包括:新手如何delphi开发数据库、DELPHI基础教程:Delphi开发数据库应用程序概述(一)[1]、学习编程,从何入手等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)