计算机二级试题及答案

计算机二级试题及答案,第1张

站长提醒广大考生:下面的138道题目,在二级考试中命中率极高。

一、选择题

(1) 下面叙述正确的是(C)

A. 算法的执行效率与数据的存储结构无关 B. 算法的空间复杂度是指算法程序中指令(或语句)的条数 C. 算法的有穷性是指算法必须能在执行有限个步骤之后终止 D. 以上三种描述都不对

(2) 以下数据结构中不属于线性数据结构的是(C)

A. 队列 B. 线性表 C. 二叉树 D. 栈

(3) 在一棵二叉树上第5层的结点数最多是(B) 注:由公式2k-1得

A. 8 B. 16 C. 32 D. 15

(4) 下面描述中,符合结构化程序设计风格的是(A)

A. 使用顺序、选择和重复(循环)三种基本控制结构表示程序的控制逻辑 B. 模块只有一个入口,可以有多个出口 C. 注重提高程序的执行效率 D. 不使用goto语句

(5) 下面概念中,不属于面向对象方法的是 (D) 注:P55-58

A. 对象 B. 继承 C. 类 D. 过程调用

(6) 在结构化方法中,用数据流程图(DFD)作为描述工具的软件开发阶段是(B)

A. 可行性分析 B. 需求分析 C. 详细设计 D. 程序编码

(7) 在软件开发中,下面任务不属于设计阶段的是(D)

A. 数据结构设计 B. 给出系统模块结构

C. 定义模块算法 D. 定义需求并建立系统模型

(8) 数据库系统的核心是(B)

A. 数据模型 B. 数据库管理系统 C. 软件工具 D. 数据库

(9) 下列叙述中正确的是(C)

A.数据库是一个独立的系统,不需要 *** 作系统的支持 B.数据库设计是指设计数据库管理系统C.数据库技术的根本目标是要解决数据共享的问题 D.数据库系统中,数据的物理结构必须与逻辑结构一致

(10) 下列模式中,能够给出数据库物理存储结构与物理存取方法的是(A) 注:P108

A. 内模式 B. 外模式 C. 概念模式 D. 逻辑模式

(11) 算法的时间复杂度是指(C)

A. 执行算法程序所需要的时间 B. 算法程序的长度 C. 算法执行过程中所需要的基本运算次数 D. 算法程序中的指令条数

(12) 算法的空间复杂度是指(D)

A. 算法程序的长度 B. 算法程序中的指令条数 C. 算法程序所占的存储空间 D. 算法执行过程中所需要的存储空间

(13) 设一棵完全二叉树共有699个结点,则在该二叉树中的叶子结点数为(B) 注:利用公式n=n0+n1+n2、n0=n2+1和完全二叉数的特点可求出

A. 349 B. 350 C. 255 D. 351

(14) 结构化程序设计主要强调的是(B)

A.程序的规模 B.程序的易读性

C.程序的执行效率 D.程序的可移植性

(15) 在软件生命周期中,能准确地确定软件系统必须做什么和必须具备哪些功能的阶段是(D) 注:即第一个阶段

A. 概要设计 B. 详细设计 C. 可行性分析 D. 需求分析

(16) 数据流图用于抽象描述一个软件的逻辑模型,数据流图由一些特定的图符构成。下列图符名标识的图符不属于数据流图合法图符的是(A) 注:P67

A. 控制流 B. 加工 C. 数据存储 D. 源和潭

(17) 软件需求分析阶段的工作,可以分为四个方面:需求获取、需求分析、编写需求规格说明书以及(B) 注:P66

A. 阶段性报告 B. 需求评审 C. 总结 D. 都不正确

(18) 下述关于数据库系统的叙述中正确的是(A)

A. 数据库系统减少了数据冗余 B. 数据库系统避免了一切冗余

C. 数据库系统中数据的一致性是指数据类型的一致 D. 数据库系统比文件系统能管理更多的数据

(19) 关系表中的每一横行称为一个(A)

A. 元组 B. 字段 C. 属性 D. 码

(20) 数据库设计包括两个方面的设计内容,它们是(A)

A. 概念设计和逻辑设计 B. 模式设计和内模式设计

C. 内模式设计和物理设计 D. 结构特性设计和行为特性设计

(21) 下列叙述中正确的是(A)

A. 线性表是线性结构 B. 栈与队列是非线性结构

C. 线性链表是非线性结构 D. 二叉树是线性结构

(22) 下列关于栈的叙述中正确的是(D)

A. 在栈中只能插入数据 B. 在栈中只能删除数据

C. 栈是先进先出的线性表 D. 栈是先进后出的线性表

(23) 下列关于队列的叙述中正确的是(C)

A. 在队列中只能插入数据 B. 在队列中只能删除数据

C. 队列是先进先出的线性表 D. 队列是先进后出的线性表

(24) 对建立良好的程序设计风格,下面描述正确的是(A) 注:P48

A. 程序应简单、清晰、可读性好 B. 符号名的命名要符合语法

C. 充分考虑程序的执行效率 D. 程序的注释可有可无

(25) 下面对对象概念描述错误的是(A) 注:P55

A. 任何对象都必须有继承性 B. 对象是属性和方法的封装体

C. 对象间的通讯靠消息传递 D. *** 作是对象的动态性属性

(26) 下面不属于软件工程的3个要素的是(D) 注:P62

A. 工具 B. 过程 C. 方法 D. 环境

(27) 程序流程图(PFD)中的箭头代表的是(B) 注:P81

A. 数据流 B. 控制流 C. 调用关系 D. 组成关系

(28) 在数据管理技术的发展过程中,经历了人工管理阶段、文件系统阶段和数据库系统阶段。其中数据独立性最高的阶段是(A)

A. 数据库系统 B. 文件系统 C. 人工管理 D. 数据项管理

(29) 用树形结构来表示实体之间联系的模型称为(B)

A. 关系模型 B. 层次模型 C. 网状模型 D. 数据模型

(30) 关系数据库管理系统能实现的专门关系运算包括(B)

A. 排序、索引、统计 B. 选择、投影、连接

C. 关联、更新、排序 D. 显示、打印、制表

(31) 算法一般都可以用哪几种控制结构组合而成(D) 注:P3

A. 循环、分支、递归 B. 顺序、循环、嵌套

C. 循环、递归、选择 D. 顺序、选择、循环

(32) 数据的存储结构是指(B) 注:P13,要牢记

A. 数据所占的存储空间量 B. 数据的逻辑结构在计算机中的表示

C. 数据在计算机中的顺序存储方式 D. 存储在外存中的数据

(33) 设有下列二叉树:图见书P46

对此二叉树中序遍历的结果为(B)

A. ABCDEF B. DBEAFC C. ABDECF D. DEBFCA

(34) 在面向对象方法中,一个对象请求另一对象为其服务的方式是通过发送(D) 注:P56

A. 调用语句 B. 命令 C. 口令 D. 消息

(35) 检查软件产品是否符合需求定义的过程称为(A) 注:P95

A. 确认测试 B. 集成测试 C. 验证测试 D. 验收测试

(36) 下列工具中属于需求分析常用工具的是(D) 注:P67

A. PAD B. PFD C. N-S D. DFD

(37) 下面不属于软件设计原则的是(C)注:P73

A. 抽象 B. 模块化 C. 自底向上 D. 信息隐蔽

(38) 索引属于(B)

A. 模式 B. 内模式 C. 外模式 D. 概念模式

(39) 在关系数据库中,用来表示实体之间联系的是(D)

A. 树结构 B. 网结构 C. 线性表 D. 二维表

(40) 将E-R图转换到关系模式时,实体与联系都可以表示成(B)

A. 属性 B. 关系 C. 键 D. 域

(41) 在下列选项中,哪个不是一个算法一般应该具有的基本特征(C)

A. 确定性 B. 可行性 C. 无穷性 D. 拥有足够的情报

(42) 希尔排序法属于哪一种类型的排序法(B)

A.交换类排序法 B.插入类排序法 C.选择类排序法 D.建堆排序法

(43) 在深度为5的满二叉树中,叶子结点的个数为(C)

A. 32 B. 31 C. 16 D. 15

(44) 对长度为N的线性表进行顺序查找,在最坏情况下所需要的比较次数为(B) 注:要牢记

A. N+1 B. N C. (N+1)/2 D. N/2

(45) 信息隐蔽的概念与下述哪一种概念直接相关(B) 注:P74

A.软件结构定义 B. 模块独立性 C. 模块类型划分 D. 模拟耦合度

(46) 面向对象的设计方法与传统的的面向过程的方法有本质不同,它的基本原理是(C)

A. 模拟现实世界中不同事物之间的联系 B. 强调模拟现实世界中的算法而不强调概念 C. 使用现实世界的概念抽象地思考问题从而自然地解决问题 D. 鼓励开发者在软件开发的绝大部分中都用实际领域的概念去思考

(47) 在结构化方法中,软件功能分解属于下列软件开发中的阶段是(C) 注:总体设计也就是概要设计

A. 详细设计 B. 需求分析 C. 总体设计 D. 编程调试

(48) 软件调试的目的是(B)注:与软件测试要对比着复习

A.发现错误 B.改正错误 C.改善软件的性能 D.挖掘软件的潜能

(49) 按条件f对关系R进行选择,其关系代数表达式为(C)

A. R|X|R B. R|X|Rf C. бf(R) D. ∏f(R)

(50) 数据库概念设计的过程中,视图设计一般有三种设计次序,以下各项中不对的是(D)注:P127,要牢记

A. 自顶向下 B. 由底向上 C. 由内向外 D. 由整体到局部

(51) 在计算机中,算法是指(C)

A. 查询方法B. 加工方法

C. 解题方案的准确而完整的描述 D. 排序方法

(52) 栈和队列的共同点是(C) 注:这一共同点和线性表不一样

A. 都是先进后出 B. 都是先进先出 C. 只允许在端点处插入和删除元素 D. 没有共同点

(53) 已知二叉树后序遍历序列是dabec,中序遍历序列是debac,它的前序遍历序列是(A) 注:P38,前提要掌握三种遍历的方法

A. cedba B. acbed C. decab D. deabc

(54) 在下列几种排序方法中,要求内存量最大的是(D) 注:要牢记,书中没有提到。

A. 插入排序 B. 选择排序 C. 快速排序 D. 归并排序

(55) 在设计程序时,应采纳的原则之一是(A) 注:和设计风格有关

A. 程序结构应有助于读者理解 B. 不限制goto语句的使用

C. 减少或取消注解行 D. 程序越短越好

(56) 下列不属于软件调试技术的是(B) 注:P98

A. 强行排错法 B. 集成测试法 C. 回溯法 D. 原因排除法

(57)下列叙述中,不属于软件需求规格说明书的作用的是(D)注:P71

A. 便于用户、开发人员进行理解和交流 B. 反映出用户问题的结构,可以作为软件开发工作的基础和依据 C. 作为确认测试和验收的依据 D. 便于开发人员进行需求分析

(58) 在数据流图(DFD)中,带有名字的箭头表示(C)

A. 控制程序的执行顺序 B. 模块之间的调用关系 C. 数据的流向 D. 程序的组成成分

(59) SQL语言又称为(C)

A. 结构化定义语言 B. 结构化控制语言

C. 结构化查询语言 D. 结构化 *** 纵语言

(60) 视图设计一般有3种设计次序,下列不属于视图设计的是(B)

A. 自顶向下 B. 由外向内 C. 由内向外 D. 自底向上

(61) 数据结构中,与所使用的计算机无关的是数据的(C)

A. 存储结构 B. 物理结构 C. 逻辑结构 D. 物理和存储结构

(62) 栈底至栈顶依次存放元素A、B、C、D,在第五个元素E入栈前,栈中元素可以出栈,则出栈序列可能是(D)

A. ABCED B. DBCEA C. CDABE D. DCBEA

(63) 线性表的顺序存储结构和线性表的链式存储结构分别是(B)

A. 顺序存取的存储结构、顺序存取的存储结构 B. 随机存取的存储结构、顺序存取的存储结构 C. 随机存取的存储结构、随机存取的存储结构 D. 任意存取的存储结构、任意存取的存储结构

(64) 在单链表中,增加头结点的目的是(A)

A. 方便运算的实现 B. 使单链表至少有一个结点 C. 标识表结点中首结点的位置 D. 说明单链表是线性表的链式存储实现

(65) 软件设计包括软件的结构、数据接口和过程设计,其中软件的过程设计是指(B) 注:P73

A. 模块间的关系 B. 系统结构部件转换成软件的过程描述 C. 软件层次结构 D. 软件开发过程

(66) 为了避免流程图在描述程序逻辑时的灵活性,提出了用方框图来代替传统的程序流程图,通常也把这种图称为(B) 注:P82

A. PAD图 B. N-S图 C. 结构图 D. 数据流图

(67) 数据处理的最小单位是(C) 注:数据项不可再分割

A. 数据 B. 数据元素 C. 数据项 D. 数据结构

(68) 下列有关数据库的描述,正确的是(C) 注:P102

A. 数据库是一个DBF文件 B. 数据库是一个关系 C. 数据库是一个结构化的数据集合 D. 数据库是一组文件

(69) 单个用户使用的数据视图的描述称为(A) 注:P108

A. 外模式 B. 概念模式 C. 内模式 D. 存储模式

(70) 需求分析阶段的任务是确定(D)

A. 软件开发方法 B. 软件开发工具 C. 软件开发费用 D. 软件系统功能

(71) 算法分析的目的是(D)注:书中没有总结,但要牢记

A. 找出数据结构的合理性 B. 找出算法中输入和输出之间的关系 C. 分析算法的易懂性和可靠性 D. 分析算法的效率以求改进

(72)链表不具有的特点是(B)

A.不必事先估计存储空间 B.可随机访问任一元素

C.插入删除不需要移动元素D.所需空间与线性表长度成正比

(73) 已知数据表A中每个元素距其最终位置不远,为节省时间,应采用的算法是(B)

A. 堆排序 B. 直接插入排序 C. 快速排序 D. 直接选择排序

(74) 用链表表示线性表的优点是(A) 注:因为不需要移动元素

A. 便于插入和删除 *** 作 B. 数据元素的物理顺序与逻辑顺序相同 C. 花费的存储空间较顺序存储少 D. 便于随机存取

(75) 下列不属于结构化分析的常用工具的是(D)注:P67

A. 数据流图 B. 数据字典 C. 判定树 D. PAD图

(76) 软件开发的结构化生命周期方法将软件生命周期划分成(A)

A. 定义、开发、运行维护 B. 设计阶段、编程阶段、测试阶段 C. 总体设计、详细设计、编程调试 D. 需求分析、功能定义、系统设计

(77) 在软件工程中,白箱测试法可用于测试程序的内部结构。此方法将程序看做是(C)注:P87

A. 循环的集合 B. 地址的集合 C. 路径的集合 D. 目标的集合

(78) 在数据管理技术发展过程中,文件系统与数据库系统的主要区别是数据库系统具有(D) 注:数据模型采用关系模型(二维表)

A. 数据无冗余 B. 数据可共享

C. 专门的数据管理软件 D. 特定的数据模型

(79) 分布式数据库系统不具有的特点是(B)

A. 分布式 B. 数据冗余

C. 数据分布性和逻辑整体性 D. 位置透明性和复制透明性

(80) 下列说法中,不属于数据模型所描述的内容的是(C) 注:P110

A. 数据结构 B. 数据 *** 作 C. 数据查询 D. 数据约束

(81)根据数据结构中各数据元素之间前后件关系的复杂程度,一般将数据结构分成(C)

A.动态结构和静态结构 B.紧凑结构和非紧凑结构

C.线性结构和非线性结构 D.内部结构和外部结构

(82)下列叙述中,错误的是(B)

A.数据的存储结构与数据处理的效率密切相关 B.数据的存储结构与数据处理的效率无关 C.数据的存储结构在计算机中所占的空间不一定是连续的 D.一种数据的逻辑结构可以有多种存储结构

(83)线性表L=(a1,a2,a3,…ai,…an),下列说法正确的是(D)

A.每个元素都有一个直接前件和直接后件 B.线性表中至少要有一个元素 C.表中诸元素的排列顺序必须是由小到大或由大到

D.除第一个元素和最后一个元素外,其余每个元素都有一个且只有一个直接前件和直接后件

(84)线性表若采用链式存储结构时,要求内存中可用存储单元的地址(D)

A.必须是连续的 B.部分地址必须是连续的

C.一定是不连续的D.连续不连续都可以

(85)栈通常采用的两种存储结构是(A)

A.顺序存储结构和链式存储结构 B.散列方式和索引方式

C.链表存储结构和数组 D.线性存储结构和非线性存储结构

(86)下列数据结构中,按先进后出原则组织数据的是(B)

A.线性链表 B.栈 C.循环链表 D.顺序表

(87)树是结点的集合,它的根结点数目是(C)

A.有且只有1 B.1或多于1 C.0或1 D.至少2

(88)具有3个结点的二叉树有(D)

A.2种形态 B.4种形态 C.7种形态D. 5种形态

(89)设一棵二叉树中有3个叶子结点,有8个度为1的结点,则该二叉树中总的结点数为(B)

A. 12B. 13 C.14D. 15

(90)在结构化程序设计思想提出之前,在程序设计中曾强调程序的效率,现在,与程序的效率相比,人们更重视程序的(C)

A.安全性 B.一致性C.可理解性 D.合理性

(91)为了提高测试的效率,应该 (D) 注:P85

A.随机选取测试数据B.取一切可能的输入数据作为测试数据C.在完成编码以后制定软件的测试计划 D.集中对付那些错误群集的程序

(92)软件生命周期中所花费用最多的阶段是(D)

A.详细设计 B.软件编码C.软件测试D.软件维护

二、填空题

(1) 算法的复杂度主要包括______复杂度和空间复杂度。 答:时间

(2) 数据的逻辑结构在计算机存储空间中的存放形式称为数据的______。答:存储结构#物理结构

(3) 若按功能划分,软件测试的方法通常分为白盒测试方法和______测试方法。答:黑盒

(4) 如果一个工人可管理多个设施,而一个设施只被一个工人管理,则实体"工人"与实体"设备"之间存在______联系。

答:一对多#1:N#1:n

(5) 关系数据库管理系统能实现的专门关系运算包括选择、连接和______。答:投影

(6) 在先左后右的原则下,根据访问根结点的次序,二叉树的遍历可以分为三种:前序遍历、______遍历和后序遍历。答:中序

(7) 结构化程序设计方法的主要原则可以概括为自顶向下、逐步求精、______和限制使用goto语句。 答:模块化

(8) 软件的调试方法主要有:强行排错法、______和原因排除法。答:回溯法

(9) 数据库系统的三级模式分别为______模式、内部级模式与外部级模式。答:概念#概念级

(10) 数据字典是各类数据描述的集合,它通常包括5个部分,即数据项、数据结构、数据流、______和处理过程。答:数据存储

(11) 设一棵完全二叉树共有500个结点,则在该二叉树中有______个叶子结点。答:250

(12) 在最坏情况下,冒泡排序的时间复杂度为______。 答:n(n-1)/2#n*(n-1)/2#O(n(n-1)/2)#O(n*(n-1)/2)

(13) 面向对象的程序设计方法中涉及的对象是系统中用来描述客观事物的一个______。答:实体

(14) 软件的需求分析阶段的工作,可以概括为四个方面:______、需求分析、编写需求规格说明书和需求评审。 答:需求获取

(15) ______是数据库应用的核心。 答:数据库设计

(16) 数据结构包括数据的______结构和数据的存储结构。

答:逻辑

(17) 软件工程研究的内容主要包括:______技术和软件工程管理。答:软件开发 注:P64

(18) 与结构化需求分析方法相对应的是______方法。

答:结构化设计

(19) 关系模型的完整性规则是对关系的某种约束条件,包括实体完整性、______和自定义完整性。答:参照完整性

(20) 数据模型按不同的应用层次分为三种类型,它们是______数据模型、逻辑数据模型和物理数据模型。答:概念 注:P110

(21) 栈的基本运算有三种:入栈、退栈和______。

答:读栈顶元素#读栈顶的元素#读出栈顶元素

(22) 在面向对象方法中,信息隐蔽是通过对象的______性来实现的。答:封装

(23) 数据流的类型有______和事务型。 答:变换型 注:P77

(24) 数据库系统中实现各种数据管理功能的核心软件称为______。答:数据库管理系统#DBMS 注:要牢记,重要

(25) 关系模型的数据 *** 纵即是建立在关系上的数据 *** 纵,一般有______、增加、删除和修改四种 *** 作。答:查询注:要牢记

(26) 实现算法所需的存储单元多少和算法的工作量大小分别称为算法的 ______。 答:空间复杂度和时间复杂度

(27) 数据结构包括数据的逻辑结构、数据的 ______以及对数据的 *** 作运算。答:存储结构注:P7

(28) 一个类可以从直接或间接的祖先中继承所有属性和方法。采用这个方法提高了软件的______。答:可重用性

(29) 面向对象的模型中,最基本的概念是对象和 ______。 答:类

(30) 软件维护活动包括以下几类:改正性维护、适应性维护、______维护和预防性维护。答:完善性注:要牢记,书中没有提到

(31) 算法的基本特征是可行性、确定性、______和拥有足够的情报。答:有穷性

(32) 顺序存储方法是把逻辑上相邻的结点存储在物理位置______的存储单元中。答:相邻

(33) Jackson结构化程序设计方法是英国的M.Jackson提出的,它是一种面向______的设计方法。答:数据结构注:P67

(34) 数据库设计分为以下6个设计阶段:需求分析阶段、______、逻辑设计阶段、物理设计阶段、实施阶段、运行和维护阶段。

答:概念设计阶段#数据库概念设计阶段

(35) 数据库保护分为:安全性控制 、______、并发性控制和数据的恢复。答:完整性控制注:要牢记

(36) 测试的目的是暴露错误,评价程序的可靠性;而______的目的是发现错误的位置并改正错误。答:调试

(37) 在最坏情况下,堆排序需要比较的次数为______。

答:O(nlog2n)

(38) 若串s="Program",则其子串的数目是______。答:29

(39) 一个项目具有一个项目主管,一个项目主管可管理多个项目,则实体"项目主管"与实体"项目"的联系属于______的联系。

答:1对多#1:N

(40) 数据库管理系统常见的数据模型有层次模型、网状模型和______三种。答:关系模型

(41)数据的逻辑结构有线性结构和_______两大类。 答非线性结构

(42)数据结构分为逻辑结构与存储结构,线性链表属于_______。答:存储结构

(43)数据的基本单位是_______。答:元素

(44)长度为n的顺序存储线性表中,当在任何位置上插入一个元素概率都相等时,插入一个元素所需移动元素的平均个数为______。

答:n/2

(45)当循环队列非空且队尾指针等于队头指针时,说明循环队列已满,不能进行入队运算。这种情况称为______。 答:上溢

(46)在面向对象方法中,类之间共享属性和 *** 作的机制称为_______。答:继承

1.DBA(数据库管理员)

DBA是数据库管理员认证,英文是Database Administrator。

DBA的一些职责:

安装和升级数据库服务器(如Oracle、Microsoft SQL server),以及应用程序工具。

数据库设计系统存储方案,并制定未来的存储需求计划。

一旦开发人员设计了一个应用,就需要DBA来创建数据库存储结构(tablespaces)。

一旦开发人员设计了一个应用,就需要DBA来创建数据库对象(tables,views,indexes)。

根据开发人员的反馈信息,必要的时候,修改数据库的结构。

登记数据库的用户,维护数据库的安全性。

保证数据库的使用符合知识产权相关法规。

控制和监控用户对数据库的存取访问。

监控和优化数据库的性能。

制定数据库备份计划,灾难出现时对数据库信息进行恢复

维护适当介质上的存档或者备份数据

备份和恢复数据库

联系数据库系统的生产厂商,跟踪技术信息

2.DBA工商管理博士

管理学科的最高学位

首先,MBA(工商管理硕士)和EMBA(高级管理人员工商管理硕士)是硕士学位,而PhD(哲学博士:现涉及哲学、政治、经济等学科)和DBA(工商管理博士)是博士学位,在研究的层度和难度上是不同的。

在欧洲,有专家已经预言DBA教育的发展前景十分乐观,有朝一日可能打破传统博士教育PhD模式一统天下的局面。和PhD一样,DBA也是正宗的美国学位,比如哈佛商学院就同时开设了PhD和DBA课程。英国在欧洲联盟中总是最快跟随美国的,所以英国已有多所大学开设了DBA的课程。

法国哥诺贝尔商学院(Grenoble Graduate School of Business—GGSB)是法国最早,也是目前唯一开设DBA项目的高等商校。实际上,其DBA项目的合作伙伴之一亨瑞管理学院(Henley Management College)亦是英国最早开设DBA课程的著名大学之一。

理论与实践紧密结合

传统的PhD模式一般为4~5年制的全职博士学习,着重纯理论的研究,一般不针对工商业界,而更偏重于管理学、经济学等,从事教学研究。而DBA教育则更多地与商务实践联系,着重理论应用于实践的效果。虽然,DBA在欧洲的学制现在一般也为4~5年,但学员是以带职学习替代全日制。与PhD一样,DBA从一开始也要求学生选择一个研究课题,知识课题本身多是学生本人在自身工作中所面临的实际问题,更具现实意义。

与中国传统博士生培养相比,DBA的教学特色将理论与实践结合得更为紧密。如果我们把MBA通常的密集型授课方式比喻为“吃”的过程,那么DBA的课程就好比“消化”的过程。运用欧美博士研究生的培养方法,针对学员自身工作中面临的问题进行系统化研究,完善公司高层管理人员管理创新能力,新项目决策优化能力,以顺应入世后瞬息万变的商务环境,做出前瞻性的战略选择。

目前,我们国内的EMBA的课程大多学费高昂,相反在学员的招生上却放得较宽,有素质参差不齐的嫌疑。有些EMBA课程往往是近百名学员组成一个班上课,而课程设置上也是以讲座的形式为主,难怪有的媒体会尖锐地称之为“一张文凭加系列讲座”。

哪些人来读DBA?

DBA教学针对的对象,大多是拥有MBA、EMBA或同等硕士学位的人才,并且至少5~6年的扎实工作经历是一份必要的资本。因为学员的总体素质本身就比较高,加上采取小班授课的形式,严格地保证了教学上的高质量。

同济大学经济与管理学院副院长吴健伟教授告诉笔者,来读DBA的学生大致可以分为三类:第一类是大学教授和博士生,他们看重DBA项目与教学研究结合紧密;第二类是工商业人士,这也是读DBA的主力军,他们来自不同的领域,比如科技管理、金融分析、网络安全以及信息软件等等,他们的目的是来寻求企业具体的解决方案;第三类是咨询业人士,因为读DBA本身就是一个结识客户、寻找机会的好机会。另外在国外,政府官员、非盈利性组织人员、慈善机构人员也会来选择DBA。

相对来说,DBA的入学要求并不算高:学生必须具有MBA或相关领域的硕士学位以及至少6年以上的工作经验,但是由于每学期限招10~15名学生,申请的难度就大了许多。据了解,2002年首届DBA项目共有42名国内外著名企业老总正式报名,经过严格筛选,最终只招了10名学员。在这些学员中有国际企业总经理、上市公司总裁、国营企业老总以及民营企业家等,都是一些中国企业的高层管理人员,起点不可谓不高。一位在哥诺贝尔商校就读DBA课程的公司总经理的话非常有代表性“我在10年前读了MBA,现在我觉得很想重返校园继续深造,进一步提高自己的理论知识来指导工作。可我已经40岁了,博士课程过去只有PhD,偏重纯理论的研究,对我的实际工作帮助不大,并且还必须辞职。而DBA则更能满足我的需要,我学到了许多最新的金融及策略管理的实践商务技能,并同步地应用于工作中。”

前者是SQL的数据对象

再次并且写法也很简单。

最重要的是在服务器的存储和运行过程都几乎是一样的,二者都是以SQL语句集存储的,而且在运行之前都是经过编译的,也就是不用每次都重新编译,这样可以大大提高执行效率。

顾名思义,其区别一个重在“过程”、一个重在“图”。

也就是存储过程涉及很多的数据处理,整个是一个复杂的过程。它可以接收参数,相当于一个函数。主要目的是用来处理数据。

而视图是把现在有数据组合成新的形式展示出来,相当于一张虚拟的表,在运行时可以当作表Table来进行查询(增删改是不行的)。其目的是用来呈现数据。

事实上,两者其内部实现是基本一样的,提供者在开发这些对象时,是针对不同目的不同应用的。

我们在使用时,同一件事情,实现的方法可以是多样的,不是说只有那者行,其他的就不行。到底使用什么来实现呢?这要对实际情况进行具体分析,看怎样实现方便,怎样实现高效。

以下是一些资料:

存储过程

存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中。用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。存储过程是数据库中的一个重要对象,任何一个设计良好的数据库应用程序都应该用到存储过程。总的来说,存储过程具有以下一些优点:

◆存储过程允许标准组件式编程

◆存储过程能够实现较快的执行速度

◆存储过程能够减少网络流量

◆存储过程可被作为一种安全机制来充分利用

基本语法如下:

完整的语法规则如下:

CREATE PROC [ EDURE ] procedure_name [ number ]

[ { @parameter data_type }

[ VARYING ] [ = default ] [ OUTPUT ]

] [ ,...n ]

[ WITH

{ RECOMPILE | ENCRYPTION | RECOMPILE , ENCRYPTION } ]

[ FOR REPLICATION ]

AS sql_statement [ ...n ]

SQL视图

视图可以被看成是虚拟表或存储查询。可通过视图访问的数据不作为独特的对象存储在数据库内。数据库内存储的是 SELECT 语句。SELECT 语句的结果集构成视图所返回的虚拟表。用户可以用引用表时所使用的方法,在 Transact-SQL 语句中通过引用视图名称来使用虚拟表。使用视图可以实现下列任一或所有功能:

将用户限定在表中的特定行上。

例如,只允许雇员看见工作跟踪表内记录其工作的行。

将用户限定在特定列上。

例如,对于那些不负责处理工资单的雇员,只允许他们看见雇员表中的姓名列、办公室列、工作电话列和部门列,而不能看见任何包含工资信息或个人信息的列。

将多个表中的列联接起来,使它们看起来象一个表。

聚合信息而非提供详细信息。

例如,显示一个列的和,或列的最大值和最小值。

通过定义 SELECT 语句以检索将在视图中显示的数据来创建视图。SELECT 语句引用的数据表称为视图的基表。在下例中,pubs 数据库中的 titleview 是一个视图,该视图选择三个基表中的数据来显示包含常用数据的虚拟表:

CREATE VIEW titleview

AS

SELECT title, au_ord, au_lname, price, ytd_sales, pub_id

FROM authors AS a

JOIN titleauthor AS ta ON (a.au_id = ta.au_id)

JOIN titles AS t ON (t.title_id = ta.title_id)

之后,可以用引用表时所使用的方法在语句中引用 titleview。

SELECT *

FROM titleview

一个视图可以引用另一个视图。例如,titleview 显示的信息对管理人员很有用,但公司通常只在季度或年度财务报表中才公布本年度截止到现在的财政数字。可以建立一个视图,在其中包含除 au_ord 和 ytd_sales 外的所有 titleview 列。使用这个新视图,客户可以获得已上市的书籍列表而不会看到财务信息:

CREATE VIEW Cust_titleview

AS

SELECT title, au_lname, price, pub_id

FROM titleview

视图可用于在多个数据库或 Microsoft? SQL Server? 2000 实例间对数据进行分区。分区视图可用于在整个服务器组内分布数据库处理。服务器组具有与服务器聚集相同的性能优点,并可用于支持最大的 Web 站点或公司数据中心的处理需求。原始表被细分为多个成员表,每个成员表包含原始表的行子集。每个成员表可放置在不同服务器的数据库中。每个服务器也可得到分区视图。分区视图使用 Transact-SQL UNION 运算符,将在所有成员表上选择的结果合并为单个结果集,该结果集的行为与整个原始表的复本完全一样。例如在三个服务器间进行表分区。在第一个服务器上定义如下的分区视图:

CREATE VIEW PartitionedView AS

SELECT *

FROM MyDatabase.dbo.PartitionTable1

UNION ALL

SELECT *

FROM Server2.MyDatabase.dbo.PartitionTable2

UNION ALL

SELECT *

FROM Server3.MyDatabase.dbo.PartitionTable3

在其它两个服务器上定义类似的分区视图。利用这三个视图,三个服务器上任何引用 PartitionedView 的 Transact-SQL 语句都将看到与原始表中相同的行为。似乎每个服务器上都存在原始表的复本一样,而实际上每个表只有一个成员表和分区视图。有关更多信息,请参见视图使用方案。

只要所做的修改只影响视图所引用的其中一个基表,就可以更新所有 SQL Server 版本内的视图(可以对其执行 UPDATE、DELETE 或 INSERT 语句)。

-- Increase the prices for publisher ’0736’ by 10%.

UPDATE titleview

SET price = price * 1.10

WHERE pub_id = ’0736’

GO

SQL Server 2000 支持可引用视图的更复杂的 INSERT、UPDATE 和 DELETE 语句。可在视图上定义 INSTEAD OF 触发器,指定必须对基表执行的个别更新以支持 INSERT、UPDATE 或 DELETE 语句。另外,分区视图还支持 INSERT、UDPATE 和 DELETE 语句修改视图所引用的多个成员表。

索引视图是 SQL Server 2000 具有的功能,可显著提高复杂视图类型的性能,这些视图类型通常在数据仓库或其它决策支持系统中出现。

视图的结果集通常不保存在数据库中,因此视图也称为虚拟表。视图的结果集动态包含在语句逻辑中并在运行时动态生成。有关更多信息,请参见视图解析。

复杂的查询(如决策支持系统中的查询)可引用基表中的大量行,并将大量信息聚积在相对较简洁的聚合中,如总和或平均值。SQL Server 2000 支持在执行此类复杂查询的视图上创建聚集索引。当执行 CREATE INDEX 语句时,视图 SELECT 的结果集将永久存储在数据库中。SQL 语句此后若引用该视图,响应时间将会显著缩短。对基本数据的修改将自动反映在视图中。

SQL Server 2000 CREATE VIEW 语句支持 SCHEMABINDING 选项,以防止视图所引用的表在视图未被调整的情况下发生改变。必须为任何创建索引的视图指定 SCHEMABINDING。

例:创建视图

Create View TitleView

AS

Select ID,Title,PostTime,Hits From [List]

然后引用Select Top 100 * From TitleView

用循环输出数据与直接Select Top 100 * From [List]相比速度提高将近30毫秒!

当然我这里只是举例子,一般情况下对单个表没必要去用视图


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/6822921.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-28
下一篇 2023-03-28

发表评论

登录后才能评论

评论列表(0条)

保存