SQL数据库的创建与管理.ppt
《SQL数据库的创建与管理.ppt》由会员分享,可在线阅读,更多相关《SQL数据库的创建与管理.ppt(55页珍藏版)》请在三一办公上搜索。
1、数据库的创建和管理,1、SQL Server 2000 服务器的结构2、创建数据库,2,SQL Server 2000 服务器的结构,RDBMS(关系型数据库管理系统)数据库,3,RDBMS,完成对数据的存储和管理操作,其主要由两部分组成:存储引擎:完成对硬盘数据的更新和访问关系引擎:完成对SQL命令的语法分析、编译、优化处理、查询执行等功能。对客户机的查询事物进行处理,向存储引擎请求数据,将处理后的结果反馈给客户机。,4,SQL SERVER 2000数据库,系统数据库:包括Master、Model、Msdb 和Tempdb,保证SQL SERVER 2000服务器正常运行和管理数据库的数据
2、库用户数据库:用户根据需要在SQL SERVER 2000服务器上创建的数据管理单位。SQL SERVER 2000服务器支持多达32000多个用户数据库。,5,SQL Server 2000 数据库的结构,从逻辑角度看SQL Server 2000数据库数据表:数据表用来存储批量的数据,数据表由行(记录)和列(字段)组成视图:数据表的窗口,定义这些窗口的位置后,用户只能查看他可以看到的数据索引:数据表中若干数据行的关键字(键值)的列表,用于快速查询数据,6,SQL Server 2000 数据库的结构,数据类型:定义将放入数据表中的数据的类型存储过程:一组SQL(结构化查询)语句的集合,类似
3、程序的模块触发器:一种特殊类型的存储过程,主要用于强制复杂的业务规则或要求,但不返回结果,用来保证数据的完整性,7,SQL Server 2000 数据库的结构,从物理角度看看SQL Server 2000数据库数据库的物理存储结构是讨论数据库文件是如何在磁盘上存储的,数据库在磁盘上是以文件为单位存储的,由数据文件和事务日志文件组成,一个数据库至少应该包含一个数据文件和一个事务日志文件。,8,1主数据文件(Primary Database File)一个数据库可以有一个或多个数据库文件,一个数据库文件只能属于一个数据库。当有多个数据库文件时,有一个文件被定义为主数据库文件(简称为主文件),其扩
4、展名为mdf。主数据库文件用来存储数据库的启动信息以及部分或者全部数据,是所有数据库文件的起点,包含指向其它数据库文件的指针。一个数据库只能有一个主数据库文件。,数据文件,9,2辅助数据库文件(Secondary Database File)用于存储主数据库文件中未存储的剩余数据和数据库对象,一个数据库可以没有辅助数据库文件,但也可以同时拥有多个辅助数据库文件。辅助数据库文件的扩展名为ndf(简称为辅助文件)。,数据文件,10,事务日志文件,SQL创建数据库的时候,会同时创建事务日志文件。事务日志文件存储数据库的更新情况等事务日志信息,当数据库损坏时,管理员使用事务日志恢复数据库。每一个数据库
5、至少必须拥有一个事务日志文件,而且允许拥有多个日志文件。事务日志文件的扩展名为ldf,日志文件的大小至少是512KB。,11,1.事务日志文件和数据文件必须分开存放,优点如下:事务日志文件可以单独备份;有可能从服务器失效的事件中将服务器恢复到最近的状态;事务日志不会抢占数据库的空间;可以很容易地监测到事务日志的空间;在向数据文件和事务日志文件写入数据时会产生较少的冲突,这有利于提高SQL的性能。,事务日志文件,12,事务日志文件,2.事务日志的工作过程在SQL中,事务是一次完成的操作的集合。虽然一个事务中可能包含了很多SQL语句,但在处理上就象他们是同一个操作似的。为了维护数据的完整性,事务必
6、须彻底完成或者根本不执行。如果一个事务只是部分地被执行,并作用于数据库,那么数据库将可能被损坏或数据的一致性遭到破坏。,13,SQL Server使用数据库的事务日志来防止没有完成的事务破坏数据。事务日志的工作过程:应用程序发出一个修改数据库中的对象的事务;当这个事务开始时,事务日志会记录一个事务开始标志,并将被影响的数据页从磁盘读入缓冲区;事务中每个数据更改语句都被记录在日志文件中,日志文件将记录一个提交事务的标记。每一个事务都会以这种方式记录在事务日志中并被立即写到硬盘上。在缓冲区中修改相应的数据。这些数据一直在缓冲区中,在检查点进程发生时,检查点进程把所有修改过的数据页写到数据库中,并在
7、事务日志中写入一个检查点标志,这个标志用于在数据库恢复过程中确定事务的起点和终点。以及哪些事务已经作用于数据库 了。,14,随着数据库数据的不断变化,事务日志文件不断增大。因此,必须把它们备份出来,为更多的事务提供空间。备份时,事务日志文件会被截断。事务日志文件包含有在系统故障下恢复数据库需要的所有信息。一般来说,事务日志文件的初始大小是以数据文件大小的10%到25%为起点的,根据数据增长的情况和修改的频率进行调整。注意:SQL Server 2000中的数据和事务日志文件不能存放在压缩文件系统或象共享网络目录等远程的网络驱动器上。,15,1.盘区和页面在创建数据库对象时,SQL Server
8、会使用盘区和页面这种特殊的数据结构给数据库对象分配空间。在SQL中,数据存储的基本单位是页。页的大小是8KB,这样数据库上每一兆字节是128页。每页的开始部分是96B的页首,用于存放系统信息,如页的类型、页的可用空间、占据该页的数据库对象的对象标识等。页有数据页、索引页、文本/图象页等6种盘区(区域)是连续8个页,可防止数据产生碎片,使SQL易于寻找。SQL有两种盘区组织页面:单一区域和混合区域。单一区域用于一个对象,混合区域用于多个小对象。事务日志不被分成页和区域,而是包含已修改数据的清单,按先来先服务的原则组织。,数据文件的存储结构,16,2.文件组文件组是文件的集合。对文件进行分组,便于
9、进行数据的管理和分配磁盘空间。例如有三个数据文件data1.ndf,data2.ndf,data3.ndf,分别位于不同的磁盘上,将这三个文件指派到文件组filegroup1中。假设在文件组filegroup1上创建一个表,对表中数据的查询将会分散到三个磁盘上,从而提高系统的查询性能。文件和文件组的设计规则:文件和文件组不能由一个以上的数据库使用;文件只能是一个文件组的成员;事务日志文件文件不属于任何一个文件组。注意:数据和事务日志不能属于同一文件或文件组。数据文件和日志文件总是分开存放的。,17,主文件组中包含了所有的系统表,当建立数据库时,主文件组包括主数据库文件和未指定组的其他文件。用户
10、定义文件组中可以指定一个缺省文件组,那么在创建数据库对象时如果没有指定将其放在哪一个文件组中,就会将它放在缺省文件组中。如果没有指定缺省文件组,则主文件组为缺省文件组。一个文件只能存在于一个文件组中,一个文件组也只能被一个数据库使用;日志文件是独立的,它不能作为任何文件组的成员。,18,估算数据库的空间需求,作为数据库管理员,主要任务之一就是创建数据库,并且需要为每个文件指定容量。必须尽可能准确地估算数据库容量,以免浪费磁盘空间资源或者因估计不足造成数据库的空间不够。许多因素会影响数据库最终的大小,在估算数据库容量时要考虑如下因素:每行记录的大小;记录数量;表的数量;索引的数量及索引大小;数据
11、库的对象的数量和大小;事务日志的大小;数据库的计划增加量;,19,创建数据库,创建数据库的三种方法:1.使用向导创建数据库 2.使用企业管理器创建数据库 3.使用Transact-SQL语言创建数据库,20,创建数据库,创建数据库的注意事项:创建数据库需要一定许可,在默认情况下,只有系统管理员和数据库拥有者可以创建数据库。数据库被创建后,创建数据库的用户自动成为该数据库的所有者。创建数据库的过程实际上就是为数据库设计名称、设计所占用的存储空间和存放文件位置的过程等,数据库名字必须遵循SQL Server命名规范。所有的新数据库都是系统样本数据库model的副本。,21,4.单个数据库可以存储在
12、单个文件上,也可以跨越多外文件存储。5.数据库的大小可以被增大或者收缩。6.当新的数据库创建时,SQL Server自动更新“sysdatabases”系统表。7.一台服务器上最多可能创建32767个数据库。,创建数据库,22,SQL Server命名规范。,名字的长度为1-128首字符必须是一个字母或者”_”、”和”#”中的任意字符在中文版SQL Server2000中,可以直接使用中文名称但名称最好不用中文,不能使用保留字,23,SQL Server 2000的文件拥有两个名称,即逻辑文件名和物理文件名。当使用Transact-SQL命令语句访问某一个文件时,必须使用该文件的逻辑名。物理文
13、件名是文件实际存储在磁盘上的文件名,而且可包含完整的磁盘目录路径。,24,使用企业管理器创建数据库使用企业管理器创建数据库比使用SQL语句来得更容易;具体步骤如下:1)进入企业管理器;2)点击SQL服务器组,进入已经配置注册的服务器,点击”数据库”项;3)点击“操作”,再选择“新建数据库”或右击数据库,在快捷菜单中选择“新建数据库”4)该窗口有三个选项卡:常规选项卡、数据文件选项卡、事务日志选项卡。5)点击“数据文件”页面标签,进行相关设置;6)点击“事务日志”选项卡,进行相关设置;7)点击“确定”。,25,使用数据库创建向导创建数据库1)进入企业管理器,分别点击“工具”菜单,“向导”;2)单
14、击“数据库”左边的“+”,展开数据库,选择“创建数据库向导”,出现欢迎窗口,进行相关的设置;3)单击“下一步”,按照向导的指示,完成数据库的创建。创建的过程与企业管理器的创建过程相似。,26,由已有库生成创建数据库的脚本由已建数据库JWGL生成该库的SQL脚本的步骤:1)选择数据库JWGL,按右键,选择“所有任务”;2)选择“生成SQL脚本”,便会产生一个“生成SQL脚本”的对话窗口;3)点击“选项”标签,点击不同的选项,可生成不同的脚本;4)点击“编写数据库脚本”复选框和“编写数据库用户和数据库角色脚本”复选框,再击点“确定”,输入脚本的文件名db_cre_text后便会生成创建数据库JWG
15、L及JWGL库的用户和角色的脚本文件 db_cre_text.sql。如要验证脚本的正确性,可进入查询分析器,调入该脚本程序执行即可。,27,使用T-SQL语言创建数据库说明:在Transact-SQL语言的命令格式中,用 括起来的内容表示是可选的;,n表示重复前面的内容;用括起来表示在实际编写语句时,用相应的内容替代;用 括起来表示是必选的;类似A|B的格式,表示A和B只能选择一个,不能同时都选。1.创建数据库的SQL语句的语法格式:CREATE DATABASE database_name ON PRIMARY,n,n LOG ON,n FOR LOAD|FOR ATTACH,28,其中:
16、:=NAME=logical_file_name,FILENAME=os_file_name,SIZE=size,MAXSIZE=max_size|UNLIMITED,FILEGROWTH=growth_increment,n:=FILEGROUP filegroup_name,n 各参数的含义(如下):database_name:新数据库的名称。数据库名称在服务器中必须唯一,最长为128个字符,并且要符合标识符的命名规则。每个服务器管理的数据库最多为32767个。ON:指定存放数据库的数据文件信息。列表用于定义主文件组的数据文件,列表用于定义用户文件组及其中的文件。,29,PRIMARY:用
17、于指定主文件组中的文件。主文件组的第一个由指定的文件是主文件。如果不指定PRIMARY关键字,则在命令中列出的第一个文件将被默认为主文件。LOG ON:指明事务日志文件的明确定义。如果没有本选项,则系统会自动产生一个文件名前缀与数据库名相同,容量为所有数据库文件大小1/4的事务日志文件。FOR LOAD:表示计划将备份直接装入新建的数据库,主要是为了和过去的SQL Server版本兼容。FOR ATTACH:表示在一组已经存在的操作系统文件中建立一个新的数据库。NAME:指定数据库的逻辑名称。FILENAME:指定数据库所在文件的操作系统文件名称和路径,该操作系统文件名和NAME的逻辑名称一一
18、对应。,30,SIZE:指定数据库的初始容量大小。如果没有指定主文件的大小,则SQL Server默认其与模板数据库中的主文件大小一致,其它数据库文件和事务日志文件则默认为1MB。指定大小的数字size可以使用KB、MB、GB和TB后缀,默认的后缀为MB。Size中不能使用小数,其最小值为512KB,默认值为1MB。主文件的size不能小于模板数据库中的主文件。MAXSIZE:指定操作系统文件可以增长到的最大尺寸。如果没有指定,则文件可以不断增长直到充满磁盘。FILEGROWTH:指定文件每次增加容量的大小,当指定数据为0时,表示文件不增长。增加量可以确定为以KB、MB作后缀的字节数或以%作后
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- SQL 数据库 创建 管理

链接地址:https://www.31ppt.com/p-6520929.html