收藏 分享(赏)

华为Sybase培训教材.doc

上传人:hyngb9260 文档编号:7493866 上传时间:2019-05-20 格式:DOC 页数:51 大小:700.50KB
下载 相关 举报
华为Sybase培训教材.doc_第1页
第1页 / 共51页
华为Sybase培训教材.doc_第2页
第2页 / 共51页
华为Sybase培训教材.doc_第3页
第3页 / 共51页
华为Sybase培训教材.doc_第4页
第4页 / 共51页
华为Sybase培训教材.doc_第5页
第5页 / 共51页
点击查看更多>>
资源描述

1、Sybase数据库培训教材华 为 技 术 有 限 公 司版权所有 侵权必究ii目 录第 1 章 Sybase 数据库简介 71.1 版本 71.2 Sybase 数据库的特点 71.3 Sybase 数据库的组成 8第 2 章 SYBASE 有关概念 102.1 数据库设备 .102.2 段 112.3 系统数据库 .112.4 用户数据库 .142.5 数据库对象 .14第 3 章 SQL 查询语言 223.1 简单查询 .223.2 连接查询 .223.3 子查询 .233.4 集函数、分组与排序 .23第 4 章 数据库、数据库对象的增、删、改 .254.1 数据库 .254.2 表 2

2、54.3 索引 264.4 默认 274.5 规则 274.6 视图 284.7 存储过程 .284.8 触发器 .29第 5 章 批处理和流控制语言 .315.1 批处理 .315.2 流控制语言 .315.3 启动 SQL Server 325.4 启动 SQL Server 的单用户模式 335.5 关闭服务器 .335.6 Sybase 数据库目录说明 33第 6 章 SQL Server 的用户及权限 356.1 建立 SQL 服务器用户名(登录帐号) 356.2 增加数据库用户名 .356.3 数据库操作授权 37iii第 7 章 数据库备份与恢复 .397.1 系统软件故障恢复

3、.397.2 介质故障的恢复 39第 8 章 几个实用程序 448.1 bcp 448.2 isql.448.3 showserver458.4 startserver .458.5 syman458.6 dbcc 数据库一致性检查 46第 9 章 Sybase 客户端软件 479.1 安装 479.2 运行 47第 10 章 附录 4910.1 附录 1:只有在 master 数据库中才能有的系统表 4910.2 附录 2:Sysusages 一行记录了分配给一个数据库的每一个磁盘分析 .4910.3 附录 3: 由 SQL Server 提供的系统过程功能和执行权 .5010.4 附录 4

4、:常用 SQL 命令 52F-4关键词:SYBASE SQL 数据库摘 要:本文主要介绍了Sybase数据库的基础知识和常用维护操作及其工具的使用,可以与N2000 产品基础共用的培训教材。5第 1 章 Sybase 数据库简介1.1 版本1984 年,Mark B. Hiffman 和 Robert Epstern 创建了 Sybase 公司,并在 1987 年推出了 Sybase 数据库产品。SYBASE 主要有三种版本,一是UNIX 操作系统下运行的版本,二是 Novell Netware 环境下运行的版本,三是 Windows NT 环境下运行的版本。对 UNIX 操作系统目前广泛应用

5、的为SYBASE 12.6。 1.2 Sybase 数据库的特点(1)它是基于客户/ 服务器体系结构的数据库一般的关系数据库都是基于主/从式的模型的。在主/ 从式的结构中,所有的应用都运行在一台机器上。用户只是通过终端发命令或简单地查看应用运行的结果。而在客户/服务器结构中,应用被分在了多台机器上运行。一台机器是另一个系统的客户,或是另外一些机器的服务器。这些机器通过局域网或广域网联接起来。客户/服务器模型的好处是: 它支持共享资源且在多台设备间平衡负载 允许容纳多个主机的环境,充分利用了企业已有的各种系统(2) 它是真正开放的数据库由于采用了客户/服务器结构,应用被分在了多台机器上运行。更进

6、一步,运行在客户端的应用不必是 Sybase 公司的产品。对于一般的关系数据库,为了让其它语言编写的应用能够访问数据库,提供了预编译。Sybase数据库,不只是简单地提供了预编译,而且公开了应用程序接口 DB-LIB,鼓励第三方编写 DB-LIB 接口。由于开放的客户 DB-LIB 允许在不同的平台使用完全相同的调用,因而使得访问 DB-LIB 的应用程序很容易从一个平台向另一个平台移植。6(3) 它是一种高性能的数据库Sybase 真正吸引人的地方还是它的高性能。体现在以下几方面: 可编程数据库通过提供存储过程,创建了一个可编程数据库。存储过程允许用户编写自己的数据库子例程。这些子例程是经过

7、预编译的,因此不必为每次调用都进行编译、优化、生成查询规划,因而查询速度要快得多。 事件驱动的触发器触发器是一种特殊的存储过程。通过触发器可以启动另一个存储过程,从而确保数据库的完整性。 多线索化Sybase 数据库的体系结构的另一个创新之处就是多线索化。一般的数据库都依靠操作系统来管理与数据库的连接。当有多个用户连接时,系统的性能会大幅度下降。Sybase 数据库不让操作系统来管理进程,把与数据库的连接当作自己的一部分来管理。此外,Sybase 的数据库引擎还代替操作系统来管理一部分硬件资源,如端口、内存、硬盘,绕过了操作系统这一环节,提高了性能。1.3 Sybase 数据库的组成Sybas

8、e 数据库主要由三部分组成:(1) 进行数据库管理和维护的一个联机的关系数据库管理系统 Sybase SQL Server;Sybase SQL Server 是个可编程的数据库管理系统,它是整个 Sybase产品的核心软件,起着数据管理、高速缓冲管理、事务管理的作用。(2) 支持数据库应用系统的建立与开发的一组前端工具 Sybase SQL Toolset;ISQL 是与 SQL Server 进行交互的一种 SQL 句法分析器。ISQL 接收用户发出的 SQL 语言,将其发送给 SQL Server,并将结果以形式化的方式显示在用户的标准输出上。DWB 是数据工作台,是 Sybase SQ

9、L Toolset 的一个主要组成部分,它的作用在于使用户能够设置和管理 SQL Server 上的数据库,并且为用户提供一种对数据库的信息执行添加、更新和检索等操作的简便方法。在 DWB7中能完成 ISQL 的所有功能,且由于 DWB 是基于窗口和菜单的,因此操作比 ISQL 简单,是一种方便实用的数据库管理工具。APT 是 Sybase 客户软件部分的主要产品之一,也是从事实际应用开发的主要环境。APT 工作台是用于建立应用程序的工具集,可以创建从非常简单到非常复杂的应用程序,它主要用于开发基于表格(Form)的应用。其用户界面采用窗口和菜单驱动方式,通过一系列的选择完成表格(Form)、

10、菜单和处理的开发。(3) 可把异构环境下其它厂商的应用软件和任何类型的数据连接在一起的接口 Sybase Open Client/Open Server。通过 Open Client 的 DB-LIB 库,应用程序可以访问 SQL Server。而通过Open Server 的 SERVER-LIB,应用程序可以访问其它的数据库管理系统。8第 2 章 SYBASE 有关概念Sybase SQL Server 是一个多库数据库系统。这些数据库包括系统数据库和用户数据库。 而不论是系统数据库还是用户数据库,都建立在数据库设备上。2.1 数据库设备所有的数据库都创建在数据库设备上。所谓数据库设备,不

11、是指一个可识别的物理设备,而是指用于存储数据库和数据库对象的磁盘原始分区或操作系统文件。增加一个新的数据库设备时,必须对这些设备“初始化”。初始化的过程就是将物理磁盘、磁盘分区或操作系统文件变为 SYBASE 数据库可以识别的设备。初始化数据库设备使用 DISK INIT 命令:DISK INITNAME=设备名,PHYSNAME=物理设备名,VDEVNO=虚拟设备号,SIZE=块数其中,NAME 指数据库设备名,此名将用于 CREATE DATABASE 和ALTER DATABASE 命令。PHYSNAME 是原始磁盘分区或操作系统文件名。VDEVNO 是数据库设备的标识号,在 SQL S

12、erver 中,它必须是唯一的。SIZE 的单位是 2K 的块,对于新创建的数据库,最小的 SIZE 是 model 数据库的尺寸,即 1024 个 2K 的块( 2M)。例如:/*将/dev 目录下 400M 的物理设备初始化为 SYBASE 的数据库设备tele114_log01*/1disk init2name=“tele114_log01”,3physname=“/dev/rtelelog”94vdevno=45size=204800 /*2Kbyte*204800=400Mbyte*/6go2.2 段数据库设备从逻辑上被划分为数据库段以允许将某一特定的对象放置在指定的段上(创建对象时

13、指定),一数据库设备可拥有多达 192 个段,一段可使用 255 个逻辑设备上的存储空间。当用户创建一个数据库时, SQL SERVER 会自动在该数据库中创建三个段: SYSTEM、LOGSEGMENT 、DEFAULT,这三个段分别用来存储数据库的系统表、事务日志和其他数据库对象在数据库中创建段的步骤是:先用 Disk init 初始化物理设备通过使用 Create database 和 alter database 的 on 子句,使数据库设备对数据库可用,于是新设备自动增加到数据库的 default 和 system 段。一旦数据库设备存在并对数据库可用,使用存储过程 Sp_addse

14、gment 定义数据库的段。语法如下:Sp_addsegment 段名,数据库名,设备名2.3 系统数据库安装 Sybase 数据库时自动生成的下列系统数据库: 主数据库 master; 模型数据库 model; 系统过程数据库 sybsystemprocs; 临时数据库 tempdb。也可选择下列数据库: 安全审核数据库 sybsecurity; 示例数据库 pubs2; 命令语法数据库 sybsyntax。10(1) master 数据库包含许多系统表和系统过程,从总体上控制用户数据库和 SQL Server的操作,构成了 SYBASE 系统的数据字典。MASTER 数据库主要记录信息为:

15、 登录帐号(SQL 服务器用户名); syslogins,sysremolelogins 正在执行的过程;sysprocesses 可修改的环境变量;sysconfigures 系统错误信息;sysmessages SQL 服务器上每个数据库的信息;sysdatabases 每个数据库占用的存储空间;sysusages 系统上安装的磁带及磁带信息;sysdevices 活动锁信息;syslocks(2) model 数据库提供了新用户数据库的初型。当我们每次用 CREATE DATABASE 命令 时,SQL Server 都产生一个 model 数据库的拷贝,然后把它扩展到命令要求的尺寸。如

16、果我们修改了 model 数据库,那么以后新创建的数据库都将随它而改变。下面是几个通常用到的对 model 数据库的改变: 增加用户数据库类型、规则或缺省; 可存取 SQL Server 上所有数据库的用户用 sp_adduser 增加到 model 数据库上; 缺省权限(特别是 guest 帐号)可在 model 中建立; 诸如 select into/bulkcopy 那样的数据库选项可在 model 中设置。这些设置反映到所有新创建的数据库中。它们在 model 中最原始的值是关( off)。在一般情况下,大多数用户无权修改 model 数据库,又没被授权读取。因为model 中所有内容

17、已拷贝到新数据库中,授权读 model 没什么意义。use modelgosp_help11goName Owner Object_type - - - sysalternates dbo system table syscolumns dbo system table syscomments dbo system table sysconstraints dbo system table sysdepends dbo system table sysgams dbo system table sysindexes dbo system table syskeys dbo system tab

18、le syslogs dbo system table sysobjects dbo system table sysprocedures dbo system table sysprotects dbo system table sysreferences dbo system table sysroles dbo system table syssegments dbo system table systhresholds dbo system table systypes dbo system table sysusermessages dbo system table sysusers

19、 dbo system table (3) sybsystemprocs 数据库库中存储系统过程,当用户执行一存储过程(以 sp_开始)时,SQL 服务器首先在用户当前数据库中搜索指定的存储过程,如果没有相应过程,则到系统过程数据库中寻找,若没有,再到 MASTER 数据库中寻找。(4)临时数据库 tempdb12该数据库为临时表和临时工作提供了一个存储区域。临时数据库是 SQL Server 上所有数据库共享的工作空间。由于这些表都是临时的,所以每当用户退出或系统失败,这些表都将消失。(5)安全审核数据库 sybsecurity数据库中保存系统的安全审核信息,它可跟踪记录每个用户的操作情况,

20、为维护系统安全提供控制手段。(6)示例数据库 pubs2为用户提供一个学习 SYBASE 的数据库模型。(7)命令语法数据库 sybsyntax库中保存 SYBASE 数据库的命令语法及支持的语言库。2.4 用户数据库用户数据库是指用 Create database 命令创建的数据库。所有新的用户数据库都要在 master 数据库中创建,也就是说,不能存取 master 数据库的用户是无权创建新的数据库的。SA 可以将创建数据库的权限授予其他用户。新建数据库中存在一些系统表,在 sysusers 表中至少有一条记录,既该数据库的创建者。数据库创建时,创建者既为该数据库的 owner, 当然创建

21、者可以将这一地位或这一所有权用系统过程授予别的用户。2.5 数据库对象(1)表(Tables)在一个关系数据库中,表是最重要的数据库对象,对应于关系数据库理论中关系,与 DBASE 或 FOXPRO 中的 DBF 文件是类似。一切数据都存放在表中。其它数据库对象都是为了用户很好地操作表中的数据。表都以一张二维表的形式存在。其中,每一列称之为一个字段,或一个域;而每一行称之为一个记录,也就是一项数据。有一类表,它们的名字都是以 sys 开头的,这些表称为系统表,系统表记录着有关 SQL Server 的信息。在 master 数据库中的表大部分为系统表,13这些表是随着 master 数据库的创

22、建而建立的。另外,每个用户数据库在创建时都有一个系统表的子集。例如,只有在 master 数据库中才有的系统表有:sysconfigures、sysdatabases、sysdevices、syslogins 等;在用户数据库和系统数据库中都有的系统表有:sysalternates、syscolumns、 sysindexs、syslogs、sysobjects 、sysusers等。例:use mastergosp_helpgoName Owner Object_type - -spt_committab dbo user table spt_datatype_info dbo user t

23、able spt_datatype_info_ext dbo user table spt_monitor dbo user tablespt_server_info dbo user table spt_values dbo user tablesysalternates dbo system table syscharsets dbo system tablesyscolumns dbo system table14syscomments dbo system tablesysconfigures dbo system tablesysconstraints dbo system tabl

24、esyscurconfigs dbo system tablesysdatabases dbo system tablesysdepends dbo system tablesysdevices dbo system table sysengines dbo system tablesysgams dbo system tablesysindexes dbo system tablesyskeys dbo system tablesyslanguages dbo system tablesyslisteners dbo system tablesyslocks dbo system table

25、sysloginroles dbo system tablesyslogins dbo system table syslogs dbo system table 15sysmessages dbo system tablesysmonitors dbo system tablesysobjects dbo system tablesysprocedures dbo system tablesysprocesses dbo system tablesysprotects dbo system tablesysreferences dbo system tablesysremotelogins

26、dbo system tablesysroles dbo system tablesyssegments dbo system tablesysservers dbo system tablesyssrvroles dbo system tablesystestlog dbo system tablesysthresholds dbo system tablesystypes dbo system tablesysusages dbo system table sysusermessages dbo system table16sysusers dbo system tablesp_confi

27、gure dbo stored proceduresp_dboption dbo stored proceduresp_getmessage dbo stored proceduresp_procxmode dbo stored proceduresp_prtsybsysmsgs dbo stored proceduresp_validlang dbo stored procedure说明见附录表 1(2)视图(Views)视图是查看一张或几张表中的数据的一种方式。通过将一张或几张表中的一部分数据进行组合得到视图。视图看上去与表非常相象,但与表还是有着本质的区别。通过视图看到的数据实际上都是存

28、放在表中的,在数据库中仅存在视图的定义。使用视图的好处是: 操作方便 安全性(3)索引(Index)索引是对字段生成的,用于加快数据的检索。在 Sybase 数据库中,索引是由系统自动管理的,也就是说,Sybase 的索引操作对用户是透明的。表的索引一旦建立,系统会自动对其进行更新维护以使它与相应表对应一致;操作时,用户无须指定索引,系统会自动确定是否使用索引进行操作。Sybase 支持三种不同类型的索引,一是复合索引,即包含几个列的索引;二是唯一性索引,即任意两行中的索引列不能有相同的取值;三是簇类索引17(Clustered indexes)和非簇类索引(Nonclustered inde

29、xs),簇类索引使SQL 服务器不断重排表行的物理顺序以使其与逻辑索引顺序相一致,非簇类索引则不需要表行的物理顺序与逻辑顺序一致。每个表最多只能建立一个簇类索引,非簇类索引则可建立多个。与非簇类索引相比,簇类索引的检索速度要快。应当在建立任何非簇类索引以前建立簇类索引。(4)存储过程(Stored procedures)存储过程是用 T-SQL 语言编写成的 SQL 子例程,它存储于 SQL 服务器上供用户调用执行。与一般的 SQL 语句和批处理语句不同的是,存储过程是经过预编译的。当首次运行一个存储过程时,SQL Server 的查询处理器将对其分析,并产生最终的执行方案。由于查询处理的大部

30、分工作已经完成,所以以后执行存储过程时速度将会很快。执行存储过程时可带参数并可调用其他存储过程,执行完毕后返回信息以指示是否成功完成相应操作。存储过程有两种:一种是 SQL 服务器安装时自动建立的系统存储过程(系统过程),另一种是用户自己创建的存储过程。系统过程是用于系统管理,并且为用户提供了从事数据库管理的一种途径。这些系统过程都是以 sp_开头的,它们都放在 master 数据库中且隶属于sa(系统管理员) 。也有很多可以在任一个数据库中运行的系统过程。常见的系统过程有:Sp_addgroup 在当前数据库中建立一个数据库用户组Sp_addlogin 建立一个SQL服务器用户Sp_addu

31、ser 在当前数据库中增加一个用户sp_changegroup 改变数据库用户组Sp_dboption 查询或改变数据库系统设置Sp_dropdevice 删除设备Sp_dropgroup 删除组Sp_droplogin 删除帐号Sp_help 查询数据库对象及所有数据库信息Sp_helpdb 查询数据库信息Sp_helpdevice 查询设备信息Sp_helpgroup 查询组信息Sp_helpindex 查询给定表信息Sp_helpuser 查询用户信息Sp_lock 查询当前加锁信息Sp_monitor 查询SQL服务器统计信息Sp_password 改变登录帐号口令Sp_spaceus

32、ed 查询表中的行数、数据页数及空间大小Sp_who 查询当前用户及过程信息Sp_syntax 查询操作语法Sp_configure 配置系统参数18例:sp_helpdbgoname db_size owner dbid created status -master 3.0 MB sa 1 Jan 01, 1900 no options setmodel 2.0 MB sa 3 Jan 01, 1900 no options setsybsystemprocs 10.0 MB sa 4 Oct 24, 1997 trunc log on chkpt tele114 370.0 MB sa 5

33、 Oct 24, 1997 select into/bulkcopy, trunc log on chkpt tempdb 22.0 MB sa 2 May 05, 1998 select into/bulkcopy(0 rows affected, return status = 0)例:sp_monitorgolast_run current_run seconds - - - May 5 1998 4:09PM May 5 1998 4:13PM 224 (0 rows affected)cpu_busy io_busy idle - - - 17(1)-0% 5(0)-0% 923(2

34、23)-99% 19(0 rows affected)packets_received packets_sent packet_errors - - - 21(9) 51(23) 0(0) (0 rows affected)total_read total_write total_errors connections - - - - 947(1) 595(113) 0(0) 3(1) (0 rows affected, return status = 0)(5)触发器(Triggers)触发器是一种特殊的存储过程,用来维护不同表中的相关数据的一致性。当在一张表中插入、删除和修改数据时,触发器就

35、会触发另一个存储过程,从而保持数据的一致性。(6)缺省与规则(Defaults and rules)缺省是在数据录入时,若用户没有输入数据,SQL Server 自动输入的值。规则是可以理解为对数据库、某一列、某用户数据类型的限制。20第 3 章 SQL 查询语言SQL 不仅包括查询数据的有关命令,还包括创建数据库及其对象,增、删、改数据等功能。分别定义为数据查询语言,数据定义语言及数据操作语言。这里先介绍数据查询语言。其基本句法为:Select select_list from table_list where search_conditions3.1 简单查询A、选择若干列Select e

36、xpression ,expression. From table_listB、选择若干行查出电话号码以 415 到头的记录Select * from code_1th where tel like 415%查询中消除值重复的行Select distinct tel from code_1th 对 Text 和 char 可用 like ,其中可用通配符%及-,分别代表多个字符和单个字符。其他常用查询条件有:(出 text 类型除外)大小比较 =、 、=、!1Having 类似于 where , 但 where 不能用聚集函数。C、用 Order by 对查询结果进行排序22Select ty

37、pe ,avg(price) from titles group by type order by avg(price)D、Compute 子句完成基于每一组中的值的聚集运算,聚集值作为一个新行出现在查询结果中。Select type ,price advance from titles order by type compute sum(price), sum(advance) by type23第 4 章 数据库、数据库对象的增、删、改4.1 数据库打开数据库 Use tele114创建数据库。拥有创建数据库权利的用户可以创建自己的数据库。CREATE DATABASE tele114ON

38、 tele114_def01=10,tele114_run01=200,tele114_idx01=200LOG ON tele114_log01=80删除数据库Drop database tele114修改数据库Alter database tele114 on tele114_run02=100, tele114_idx02=1004.2 表建表create table spec_code(No tinyint not null, /*特编号(0-99)*/Name varchar(50) null, /*名称*/Addr varchar(50) null, /*地址*/Tel varch

39、ar(8) null, /*电话号码*/StaffNo varchar(4) not null /*录入员工号*/)on segrun /*将表放在 segrun 段上*/删除表24Drop tabel tele114_1th修改表,在表中增加新的列(用这个命令增加的列必须允许 null 值)Alter table friends_etc add country varchar(20 ) null 表级或列级约束Create table my_publishers (pub_id char(4),Pub_name carchar(40).Constraint my_chk_constraint

40、Check (pub_id in (1389,0736,0877)Or (pub_name not like bad news books)指定默认值Create table ny_titles(title_id char(6t),Title varchar(80),Price money default null,Total_sales int default (0)指定 Unique 和 primary key 约束Primary key 不允许空值,常用来产生唯一的聚集索引,unique 允许空值,常用来产生唯一的非聚集索引Create table my_sales(stor_id ch

41、ar(4),Ord_num varchar(20),Date datetime,Unique clustered(stor_id,ord_num)4.3 索引建立索引create unique clustered index code1thidx1 on code_1th(Code1,Name,UnitNo1,Used)25on segrunUnique: 建立唯一性索引Clustered : 建立聚集索引,使得数据行的逻辑顺序与物理顺序一致,查询速度较快;每个表仅允许建立一个唯一性索引。(非聚集索引 nonclustered)On segrun:将索引放在 segrun 上删除索引: dro

42、p index code_1th.code1thidx14.4 默认当用户没有显示地为某一列赋值时,SQL SERVER 为该列插入的值创建默认值 CA,把默认值 CA 用到 friends_etc 表中的 State 列上Creat default statedfltGoSp_bindefault statedflt, “frends_etc.state“go断离默认Sp_unbindefault “frends_etc.state“删除默认Drop default statedflt4.5 规则可以理解为对数据库、某一列、某用户数据类型的限制.规则中的任何变量名必须冠以,不能直接引用列或其他数据库对象。创建规则并把他关联到用户定义的数据类型 P#上Create rule phonerule as phone like 4150-90-90-90-9Sp_bindrule phonerule ,“p#“断离规则Sp_unbindrule “p#“删除规

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报