1、武汉理工大学 毕业设计(论文) 人事档案管理系统 学院(系): 专业班级: 学生姓名: 指导教师: -------------摘要-------------- 人事档案管理系统是典型的信息管理系统,其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面。对于前者要求建立起数据一致性和完整性强、数据安全性好的库。而对于后者则要求应用程序功能完备,易使用等特点。 随着科学技术的不断提高,计算机科学
2、日渐成熟,其强大的功能已为人们深刻认识,它已进入人类社会的各个领域并发挥着越来越重要的作用。DELPHI是面向对象的开发工具,尤其是数据窗口这一能方便而简洁操纵数据库的智能化对象,首先在短时间内建立系统应用原型,然后,不断修正和改进,直到形成用户满意的可行系统。 关键字:控件、窗体、表。 -------------前言-------------- 对于大多数国企而言,他们有一套比较系统的人力资源管理理念,并建立了一整套比较规范的人力资源管理方法。在积极建立企业现代企业管理机制的今天,仅仅靠原始的手工管理或简单的单机管理,人力资源部门面对大量的信息,
3、无法有效率地将其中的重要部分提取出来,并做出相应的判断和处理。集团管理者的决策只能依据报表数据,在浪费大量人力、物力的同时无法做到实时监控,难以保证数据的准确性和及时性。因此,先进的管理思想在企业中实现就成为了一个可望而不可及的目标。 作为计算机应用的一部分,使用计算机对人事进行管理,具有着手工管理所无法比拟的优点.例如:检索迅速、查找方便、可靠性高、存储量大、保密性好、寿命长、成本低等。这些优点能够极大地提高商场人事管理的效率,也是科学化、正规化管理的重要条件。 因此,开发这样一套管理软件成为很有必要的事情,在下面的各章中我们将以开发一套人事管理系统为例,谈谈其开发过程和
4、所涉及到的问题及解决方法。 第一章 为什么要开发一个人事管理系统? 计算机已经成为我们学习和工作的得力助手: 人力资源系统选型时提出了以下要求: 1).具有先进的人力资源管理理念; 2).可以满足多行业、多公司不同的人力资源管理要求; 3).实现集团化管理,实时监控各个专业、省市子公司的人力资源情况; 4).进行多层次数据汇总,为各层次管理者的决策分析提供数据; 5).具有完整的系统接口,满足灵活的数据导入与导出。。 第二章 人事管理系统编程环境现状及设计目标简介 2.1
5、 Delphi和ADO Active Data Objects结合了OLE DB的普遍性质—那就是在诸如RDO和DAO模型中可以找到的易于使用的特性.ADO包含了所有可以被OLE DB标准接口描述的数据类型.换而言之,ADO是可扩充的,不需要对你的部件做任何工作.数据的访问和操纵是任何实际的应用程序的一个固有部分.对于数据来说,无论它是否是关系型的,无论它是否存在一个DBMS,也无论它的存储平台是什么,数据就是数据—一个文件没有必要一定是给定的二进制格式. 开发者群体需要具有简单接口的现代的开发工具以快速访问数据.微软对此问题的回答是Universal Data Access(
6、UDA通用数据访问)体系结构,对此,Stephen Rauch的文章 “Manage Data from MyriadSources with the Universal Data Access Interfaces”中有详细的阐述(MSJ,1997年9月).简单的说,UDA是一种将OLE DB应用于实际的理论.所有的都被指向一个数据源—一个电子表格,一条电子邮件消息,或一份AS/400文档—由OLE DB接口过滤并以一种通用的格式表示,这样应用程序能总是以同样的方式对数据进行访问.位于OLE DB上的并处理来自应用程序的调用的中间层被称作Active Data Objects (ADO).它
7、是编写针对带有OLE DB提供者的任何类型的数据源的推荐标准. 在ADO之前的RDO是一种增加DAO的客户/服务器能力,以提高其性能和可扩充性的当然的方法.根本上说来, RDO是一种位于ODBC API的上层的简便的封装.它揭示了了DAO数据对象模型中的许多东西,但它缺乏进行数据访问的Jet引擎.虽然这将予ADO更快的速度,但它没法利用该引擎的许多特性,而且它只能访问关系型的数据库. ADO 2.0的思想就在于:为不同的应用程序访问相同的数据源创建一个更高层的公用层.尽管存在数据结构和组织间的物理位置的不同,编程的接口应该是一样的.为了找出RDO和ADO之间的更多的不同, “Explo
8、ringActiveX Data Objects from an RDO Point of View,"你能在MSDN的技术性文章部分中找到它.ADO的出现并不意味着RDO的结束.实际上,微软承诺在可以预见的将来继续支持RDO ADO 2.0有什么新特点? 对于ADO1.5以前包括1.5的版本来说,从功能的角度来看RDO和ADO不是完全相等的.等同就意味着你可以通过这两种方法解决同样的问题;它不是指存在重命名的或者优化的功能相同的对象.因此,移植到ADO不是一个简单的事情.从另一方面来说,一旦你熟练掌握了RDO或DAO技术的话,学习ADO是件相当容易的事情 ADO 2.0的新特
9、性包括事件处理,记录集的延续,分层目录结构指针和数据成形,分布式事务处理,多维数据,远程数据服务(RDS),以及对C++和Java的支持的增强.在钻研一些Visual Basic代码的时候将会见到所有的这些特性. ADO对象模型是由相对数量较少的对象组成.不象RDO对象模型,每个主要的ADO对象都能被个别的被创建. 这就意味着,举例说吧,你不需要在创建有效的记录集对象前创建一个连接. Dim cn As New ADODB.Connection Dim rs As New ADODB.Recordset cn.Open "Biblio" rs.Open "select * fr
10、om titles where title like '%h'", cn ADO 2.0对象是Connection,Command,Parameter,Recordset,Field,Error和Property.ADO对象模型也包 括四个类集:它们分别是一套相关的Error,Parameter,Property和Field对象.让我们来看看每个对象的主要特性. Connection对象提供连接,该连接连接的程序中存有它正在访问的数据源.属性允许你定义:连接串,命令执行以及连接启动的间隔时间,数据提供者,(无论临时表位置是应该在客户端还是在服务器端),和对于数据的访问权限.方法有关于如下
11、功能的:执行命令,打开和关闭一个连接和管理事务.在许多地方你可以指定你想使用的提供者:通过Provider属性,在连接字符串中,或者甚至通过Open方法. 选择你最喜欢的实现方式,但要保证你没有为同样的连接指定多个的提供者.缺省的提供者(当你没有指定你自己的提供者的情况下)是MSDASQL,针对ODBC的Microsoft OLE DB提供者. Command对象定义了一个SQL声明,一个存储过程,或任何其他的你可能想让提供者执行的关于数据的操作.Command的属性有:当前连接,最大允许执行时间和参数集.一个参数就是你将它作为参数传递给命令的值.在这些属性中用以区分一个参数的属
12、性有:方向(输入,输出,或者两者都有),类型当然还有它们的值. 记录集对象也许是最典型的ADO对象,然而它是最复杂的当中的一个.它表示命令执行的结果,并且它大多是以数据库的记录集的形式给出.一个记录集是由以行和域的形式表示的信息组成.它不一定非要映射成关系型数据库的记录.实际上,如同我早些时候解释的那样,ADO是基于OLE DB并且能被用来可视化地访问任何数据源中的数据,这数据源包括非关系型的数据库.记录集提供了缓冲能力,它接受数据的变化,并且将这些变化以批处理的方式传给服务器.你可以浏览并对记录集的内容分类,如同列举和提取行.你也能通过如:删除,添加和刷新操作等任何方式修改数据
13、记录集存在跟连接的严格的关系,但是这不意味着 你总是需要一个打开的连接来获得一个记录集.你也可以按如下方式进行: Dim RS As New ADODB.Recordset sql = "select * from authors" RS.Open sql, "Pubs" 既然Connection实际上是数据和命令传送的通道,所以该对象仍然被创建了,除了一个名字叫做 Recordset.ActiveConnection的属性外,它是不可见的并工作在后台. Field对象是一列同类的数据.它提供了一种这样的编程接口,即能让你可以对单个单元的值以及基本的特征如:类型和大小
14、进行读和写.所有给定记录集的Field对象形成了一个Field集.如我将在后面向你说明的, Fields集隐藏着一个引人注目的特性,它将再次证明Recordset对象的灵活性.最后是Property对象.每个对象都有属性.提供的使用了ADO的对象可能是各种各样的.但不存在这样一套属性即包含了所有可能的OLE DB提供者的静态的属性.因此,任何一个ADO对象都有静态和动态的属性.第一套属性集:包括Name,Type,Value和Attributes,都可以通过如下的语法来访问:obj.PropertyName最开始的三个属性都是自我说明性的.Attributes是一种数字式的描述符,它是以按位的
15、跟提供者的能力有关的一些预定义的属性组合.(它类似于COM服务器的组件分类).动态属性是跟潜在的提供者类型相应的.它们被归进Properties集合,并可以通过名字查询. obj.Properties("propName") The New Recordset Object 2.2 sql介绍 通过SQL命令,程序设计师或数据库管理员(DBA)可以: (一)建立数据库的表格。(包括设置表格所可以使用之空间) (二)改变数据库系统环境设置。 (三)针对某个数据库或表格,授予用户存取权限。 (四)对数据库表格建立索引值。 (五)修改数据库表格结构。
16、新建、删除或是修改表格字段) (六)对数据库进行数据的新建。 (七)对数据库进行数据的删除。 (八)对数据库进行数据的修改。 (九)对数据库进行数据的查询。 这几项便是通过SQL命令可以完成的事情,看起来是不是比起“查询”两个字所代表的功能要多的多了呢? SQL语法的分类 其实SQL命令并不是非常多,可是要把SQL用到出神入化,却也只需要短短几个命令便够,因为SQL命令是针对关系型数据库所建立出来的语法叙述,所以SQL在这类数据库中所发挥的功能非常的强,以下将针对在VB中常用的SQL语法基本命令加以分类介绍。在说明SQL的命令以及使用语法之前,以下
17、将SQL做了的分类,在致上SQL语法所使用到的类型,可以说都已包含在这些类别当中。 第一类、属性词(Predicates) 在SQL命令中用来指明所要选择的记录的方式。如ALL、TOP与DISTINCT等等。 第二类、声明(Declaration) 针对SQL Parameter或Parameter Query 的名称与数据类型做声明,如PARAMETERS的声明等等。 第三类、条件子句(Clause) 在SQL的查询中,利用一些表达式定义出查询的条件,以缩小寻找的范围,如WHERE。 第四类、运算符(Operator)与操作数(Operation)
18、 在SQL的查询中,与Operation共同组成表达式(Expression),如BETWEEN....AND 运算符与INNER JOIN操作数。 第五类、函数(Function) 一些SQL常见的函数,像是AVG()是求算数平均数的函数。 第六类、SQL语句(Statement) SQL的语句,可以说是SQL语法的主体,用来对某一个特定的数据库发出指示,并返回相关的数据,而SQL的语法结构,基本上可以利用下面 的式子来表示:命令+条件子句 例如: SELECT*FROM TAB WHERE TAB.NAME='A' 其中的“FROM..
19、WHERE”便是一个条件子句,其实SQL的语法并不难,您只需记住这样的一个规则,相信可以很快的了解SQL用法。 SQL语法与命令 SELECT 语句 SELECT[predicate]{*|table.*|[table.]field [,[table.]field2[,...]]} [AS alias1 [,alias2[,...]]] FROM tableexpression [,...][IN externaldatabase] [WHERE...] [GROUP BY...] [HAVING...] [ORDER BY...] [WITH OWNERA
20、CCESS OPTION] SELECT 语句包括下面几个部分 predicate 如前面所述,包括了ALL,DISTINCT,DISTINCTROW,与TOP 我们可以利用这样的语句去限制查询后所得的结果。 * 从指定表格中指定所有的字段。 table 针对被选择出的记录的字段,所指定表格的名称。 field1,field2 想要读取数据的字段名称,如果包含了一个以上的字段,会依照列出的顺序来读取数据。 alias1,alias2 用来替代在表格实际字段名称的化名。 tableexpression 表格名称或包含我们
21、所想要的数据的表格。 externaldatabase 若使用到不是目前的数据库则将其名字定义在externaldatabase当中。 ALL,DISTINCT,DISTINCTROW,TOP属性词用法 SELECT [ALL|DISTINCT|DISTINCTROW|[TOP n[PERCENT]]] FROM table ALL 若是不指定任何的字段数据,则Microsoft Jet数据库引擎(database engine)将会选择所有的字段,并依据所定的条件查询出需求数据集。 例如下面这两个例子将会具有相同的效果,都会从职员表格中返回所有字
22、段的数据。 例如: 若是我们要查询出职员表格中的所有记录,可以通过下面的语句来完成。 SELECT ALL* FROM 职员表格; DISTINCT 对某个表格所选择的字段数据,略过重复的情况,也就是说,针对某个字段查询出来的记录结果是唯一的。例如有许多存放在职员表格的职员 数据,也许会具有相同的姓名,所以若是我们用SQL语句中的SELECT DISTINCT,则查询出来的结果将会针对不一样的姓名加以筛选。若是您把 DISTINCT 加以省略,则这样的查询会显示所有的记录。 DISTINCTROW 将整条记录重复的记录忽略掉,而不是只有
23、针对某一个字段的数据。 table 指定查询记录所需要的表格。 例如: SELECT DISTINCTROW 公司名称 FROM 顾客表格 INNER JOIN 订单表格 ON 顾客表格.顾客ID=订单表格.顾客ID ORDER BY 公司名称; 如果您忽略 DISTINCTROW 则会对每个公司产生一行以下的订单数据。此外,若是DISTINCTROW只有用在一个表格当中,则会被省略掉。 TOP 从第一条或最后一条开始(利用ORDER BY条件子句),返回特定条数的数据。 例如: 当您想要知道在2000年,班上前25名
24、的学生姓名数据时,您可以输入这样的语句: SELECT TOP 25 学生姓名 FORM 学生表格 WHERE 毕业年份=1994 ORDER BY 毕业成绩平均分数 DESC; 如果您没有加上ORDER BY 这行条件的话,您所得到的数据,将会随机的数据。此外,在TOP语句之后,除了可以加上数字以外,还可以利用保留 字PERCENT来查询。 例如: SELECT TOP 10 PERCENT学生姓名 FROM学生表格 WHERE毕业年份=1994 ORDER BY毕业成绩平均DESC; PARAMETERS(参数)
25、声明的用法 对于参数型的查询语法中,对参数的名称以及数据类型作 声明的操作。 PARAMETERS name datatype[,name datatype[,...]] name PARAMETERS的名称。您可以把参数名称当作字符串来使用,若是名称中包含了空字符串,可以利用中括号来处理,例如:“VBeden”。 datatype 输入参数的数据类型。 例如: 若是您在查询时,需要机动的输入姓名 ,可以利用下列的方式完成: PARAMETERS “输入姓名” Text; SELECT* FROM 职员表格 WHERE姓
26、名=“输入姓名:”; ORDER BY条件语句 此条件子句,通常与SELECT语句合并使用目的是将查询的结果,依照指定字段加以排序。 SELECT fieldlist FROM table WHERE selectcriteria ORDER BY field[ASC|DESC][,field2[ASC|DESC][,...]] fieldlist 欲查询的字段名称。其中可以与ALL,DISTINCT,DISINCTROW,或TOP一起来使用。 table 欲查询的表格名称。 selectcriteria 查询的标准设置
27、 field1 指定要依照那个字段作为排序的依据,若是你没有加上ORDER BY查询出的数据集将不会作排序的操作。 ASC 递增顺序类别。(默认值) DESC 递减顺序类别。 例如: 或是我们要将输出数据依据出生的先后次序排列,可以利用下面的命令。 SELECT 姓名,生日 FROM 职员表格 ORDER BY 生日 SELECT LastName,FirstName FROM Employees ORDER BY LastName ASC; IN 条件子句 指定要速胜哪一个外
28、部数据库的表格。(必须是Microsoft Jet数据库引擎所可以连接的数据库,如dBase,Paradox等等) SELECT|INSERT]INTO destination IN {path|["path" "type"]|[""[type;DATABASE=path]]} FROM tableexpression IN {path|["path" "type"]|[""[type;DATABASE=path]]} destination 欲插入数据的外部表格名称。 tableexpression 表格名称或是被读取数据的表格名称。这个参数可以是
29、一个单一的表格名称,或是一段已经被存储的SQL查询等。 path 包含该表格的完整路径名称。 type 数据库的类型名称, 通常是当数据库部属于Jet database时才会使用。(例如:dBASE III,dBASE IV,Paradox 3.x,Paradox 4.x,或 Btrieve) 例如:下面这两段的意义相同 PartA....FROM Table IN ""[dBASE IV;DATABASE=C:\DBASE\DATA\SALES;]; PartB....FROM Table IN "C:\DBASE\DATA\SALES"
30、"dBASE IV;" 例如:Microsoft Jet database SELECT 顾客编号 FROM 顾客表格 IN CUSTOMER.MDB WHERE 顾客编号 Like "A*"; 其中CUSTOMER.MDBO 为Jet database 的数据库名称,其中包含了顾客表格。 例如:dBASE III or IV SELECT 顾客编号 FROM 顾客表格 IN "C:\DBASE\DATA\SALES" "dBASE IV;" WHERE 顾客编号 Like "A*"; 所以当我们使用不同于ACCESS 的数据库时,必须指明该数据库的类型名称
31、 HAVING 条件子句 指定一特定的分组记录,并满足HAVING 所指定的条件或状态,但条件是针对分组的条件设置。 SELECT fieldlist FROM table WHERE selectcriteria GROUP BY groupfieldlist HAVING groupcriteria fieldlist 显示被查询的字段名称。(可与ALL,DISTINCT,DISTINCTROW,或TOP相结合) table 欲查询数据的表格名称。 selectcriteria 选取标准。 groupfieldlist 分组记录的字段名称
32、到多10个字段。而这些字段的顺序决定最高到最低的分组阶层。 groupcriteria 决定什么样的分组记录要被显示。 HAVING跟WHERE 的用法相当类似,不同之处在于HAVING必须用于GROUP之后的分组数据上。 例如: SELECT 分类编,Sum(库存数量) FROM 产品表格 GROUP BY 分类编号 HAVING Sum(库存数量)>100 AND 产品名称 LIKE "*纸"; GROUP BY 条件子句 依据指定的字段,将具有相同数值的记录合并成一条。 SELECT fieldlist FROM table WHERE cr
33、iteria GROUP BY groupfieldlist fieldlist 欲读取的字段名称。(可与ALL,DISTINCT,DISTINCTROW,或TOP合并使用) table 被查询的表格名称。 groupfieldlist 分组记录的字段名称,到多10个字段,而这些字段的顺序决定最高到最低的分组层次。 例如: SELECT 姓名,Count(姓名)AS 职员姓名 FROM 职员表格 WHERE 部门名称='业务部' GROUP BY 姓名 FROM 条件子句 指定表格名称或是查询,其中包含列在SELECT语句的字段数据。 S
34、ELECT fieldlist FROM tableexpression[IN externaldatabase] fieldlist 表格中的字段名称。(可与ALL,DISTINCT,DISTINCTROW,或TOP相结合) tableexpression 表格名称,或多个表格的算式。 externaldatabase 若该表格参考到外部的数据库时,将其完整的路径名称记下。 例如: 从职员表格下,查询出所有姓名字段的数据(只有姓名字段被查询,其他则不显示)。 SELECT 姓名 FROM 职员表格; WHERE 条件子句 指定查询的条件与限
35、制。 SELECT fieldlist FROM tableexpression WHERE criteria fieldlist 字段名称。(可与ALL,DISTINCT,DISTINCTROW,或TOP相结合) tableexpression 表格名称,或多个表格的算式。 criteria 查询的结果,必须依照这一限制标准。 例如: 要查询出职员表格中,所有姓氏是李的数据,可以用下面的语句。 SELECT 姓名 FROM 职员表格 WHERE 姓氏='李'; BETWEEN...AND 运算符 决定某一人数值是否介于特定的范围之内,此运算符只
36、可以用在SQL的语句中。 expr[Not]BETWEEN value1 AND value2 expr 指定要加以计算的字段与表达式的组合。 value1,value2 所指明的数值范围。 例如: 若是要从职员表格查询出所有年龄介于25-30岁的员工,可以利用下面的程序来做。 SELECT 姓名,年龄 BETWEEN 25 AND 30 FROM 职员表格; LIKE 操作数 用来将一字符串与另一特定字符串样式(pattern)比较,并将符合该字符串样式的记录过滤出来。 expression LIKE "pattern" express
37、ion 使用在WHERE条件子句,SQL表达式。 pattern 用以比较的字符串样式。 例如: 若是你要查询出所有以“李”为首的姓氏,可以利用下面的式子。 Like "李*" LIKE操作数的多种范例: 1、多个字符: (1)"a*a" 可筛选:"aa","aBa","aBBBa",不能筛选:"aBC" (2)"*ab*" 可筛选:"abc","AABB","Xab",不能筛选:"aZb","bac" 2、特殊字符: "a“*”a" 可筛选:"a*a",不能筛选:"aaa" 3、单一字符: "a?a" 可筛选:"aaa","a3a","aBa"
38、不能筛选:"aBBBa" 4、单一数字: "a#a" 可筛选:"a0a","a1a","a2a",不能筛选:"aaa","a10a" 5、字符范围: "“a-z”" 可筛选:"f","p","j",不能筛选:"2","&" 6、指定字符以外部范围: "“!a-z”" 7、指定非数字: "“!0-9”" 可筛选:"A","a","&","~",不能筛选:"0","1","9" 8、组合式结构: "a“!b-m”#" 可筛选:"An9","az0","a99",不能筛选:"abc","aj0" SQL数字函数 1、AVG:算数平均数 AV
39、G(expr) expr 字段名称或表达式。 例如: 若要计算职员身高超过165厘米的职员平均身高,可以利用下面的SQL语句来完成。 SELECT Avg(身高) AS 平均身高 FROM 职员表格 WHERE 身高>165; 2、COUNT:计算记录条数 COUNT(expr) expr 字段名称或表达式。 例如: 若是要统计出业务部门的职员人数,并查询出职员的姓名,可以利用下面的程序。 SELECT Count(姓名) AS 职员姓名 FROM 职员表格 WHERE 部门名称='业务部';
40、 3、FIRST与LAST:返回某字段的第一条数据与最后一条数据。 FIRST(expr) LAST(expr) expr 字段名称或表达式。 例如: 若是要找出货品数量字段的第一条数据与货品价格字段的最后一条数据时,可以利用下面的查询方式。 SELECT FIRST(货品数量),LAST(货品价格) FROM 订单表格 4、MAX,与MIN:返回某字段的最大值与最小值。 用法同FIRST与LAST。 5、SUM:返回某特定字段或是运算的总和数值。 SUM(expr) expr 字段名称或表达式
41、 例如: 要计算出货品总价,可使用下面的程序。 SELECT Sum(单位价格*货品数量) AS 货品总价 FROM 订单表格 多层SQL查询 顾名思义,多层的SQL查询的便在于:“在一个SQL语句中可以包含另一个SQL查询语句,形成内部嵌套的查询类型。” comparison[ANY|ALL|SOME](sqlstatement) expression[NOT]IN (sqlstatement) [NOT]EXISTS(sqlstatement) comparison 将表达式与内层查询的结果比较的操作。 expression
42、对内层查询的结果作搜索的表达式。 sqlstatement 为SELECT语句构成的SQL查询,必须用()将该语句括起来。 例如: 我们先从订单表格当中,查询出所有的单位,再将产品表格中的单位与的一一对比,查询出所有高于订单表格的单位价格的记录。 SELECT * FROM 产品表格 WHERE 单位价格>ANY (SELECT 单位价格 FROM 订单表格 WHERE 折扣>=.25); 5)表中的每一个列值必须是不可分割的基本数据项。 注意:当用户需要新的数据结构或表存放数据时,首先要生成一个表。 语法: CREATE TABLE
43、表名 [表约束] (列名1 数据类型 [缺省值1,列约束1] (列名2 数据类型 [缺省值2,列约束2] … 列名n 数据类型 [缺省值n,列约束n] [TABLESPACE 表空间名称] [STORAGE (存贮的子句)] [ENABLE 约束名] [DISABLE 约束名] · 插入数据 当一个表新建成时,它里面没有数据,通过向表中扦入数据,建成表的实例。 语句句法: INSERT INTO 表名[(列名1,…)] VALUES(值1,值2,…,值n) [子查询]; 假设有一张表Student如下所示: NO NAME AGE 1001
44、 A 12 1002 B 14 将新学生E增加到上表中,并按照表的结构将信息添加完整,需要如下语句: INSERT INTO STUDENT VALUSE(1003, 'E',12); · 修改数据 对表中已有数据进行修改,语句句法: UPDATE 表名SET 列名1=表达式1,列名2=表达式2,… WHERE 条件; 例如:对下表Student NO NAME AGE 1001 A 12 1002 B 14 将B的年纪改为18;应该执行以下语句: UPDATE STUDENT SET AGE=18 WHERE NAME='B';
45、 · 删除数据 删除表中已有数据,不能删除不存在的数据。 语句句法: DELETE FROM 表名 WHERE 条件; 例如: 对下面Student表进行删除,要删除其中年纪为12的学生; NO NAME AGE 1001 A 12 1002 B 14 DELETE FROM STUDENT WHERE AGE=12; · 表结构的修改 在已存在的表中增加新列,语句句法: ALTER TABLE 表名 ADD(新列名 数据类型(长度)); 例如: ALTER TABLE STUDENT ADD (DEPARTMENT CHAR(8
46、)); b.增加已有列的数据类型。 例如: ALTER TABLE STUDENT MODIFY(NAME VARCHAR2(25)); · 表的删除 将已经存在的表删除,语句句法: DROP TABLE表名; 例如: DROP TABLE EMP; · 查询语句 SELECT命令的语法为: SELECT [DISTINCT|ALL] {*|模式名.] {表名|视图名| 快照名] .*…| {表达式[列别名]…} } [, [模式名. ] {表名| 视图名|} .*…| 表达式[列别名] ]… FROM [
47、模式名.] {表名|视图名|快照名} [@数据库链名] [表别名] [, [模式名.] {表名|视图名|快照名} [@数据库链名] [表别名] ]… [WHERE条件] [START WITH条件 CONNECT BY 条件] [GROUP BY表达式[,表达式] …[HAVING条件] [UNION|UNION ALL |INTERSECT|MINUS]SELECT命令 [ORDER BY{表达式|位置} [ASC|DESC] [, {表达式|位置[ASC|DESC]}]…] 例如:对于STUDENT表: NO NAME AGE 1001 AE 12 1002
48、 BT 14 (1) 查询年纪为12的学生姓名; SELECT STUDENT.NAME FROM STUDENT WHERE AGE=12; (2) 查询年纪在12至16岁之间的学生姓名; SELECT STUDENT.NAME FROM STUDENT WHERE AGE BETWEEN 12 AND 16; (3) 查询年纪不在12至16岁之间的学生姓名; SELECT STUDENT.NAME FROM STUDENT WHERE AGE NOT BETWEEN 12 AND 16; (4) 查询所有姓名以A开头的学生的姓名; SELECT STUDENT.NAME
49、FROM STUDENT WHERE NAME LIKE 'A%'; (5) 列出所有学生年纪的和,年纪的平均值,最大值,最小值,最大值与最小值之间的差值; SELECT AVG(AGE), SUM(AGE), MAX(AGE), MIN(AGE), MAX(AGE)-MIN(AGE); (6) 将所有学生按学号顺序升序排列; SELECT * FROM STUDENT ORDER BY NO DESC; (7) 将所有学生按学号顺序升序排列; SELECT * FROM STUDENT ORDER BY NO ASC; 第三章 关键问题:使用关系型数据库 使用DELP
50、HI 7.0 实现关系型数据库 数据库的概念 使用中文Access 2000可以从单一的数据库文件中组织用户信息。在此文件中,可将数据分开放在名为“表”,也就是前面所说的“数据表”的容器中,然后可使用联机窗体让网络用户查看、添加并更新表中的数据、“查询”查找并检索数据、使用“报表”按特定的布局分析或打印的数据。此外,通过创建数据访问页还能从Internet上查看与更新或分析数据。与前面所介绍的两个软件一样,为了存储与使用数据,可对每一类信息创建一张表,此后就能在窗体、报表、或数据访问页中将多个表中的数据组织到一起,以及定义表之间的关系,以便于查找和检索仅满足指定条件的数据






