数据库的实现_第1页
数据库的实现_第2页
数据库的实现_第3页
数据库的实现_第4页
数据库的实现_第5页
已阅读5页,还剩27页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、ACCP V4.0第二章第二章数据库的实现ACCP V4.02回顾q在需求分析阶段,设计数据库的一般步骤为?q实体的映射关系有哪些?q请简要说明三大范式的含义?ACCP V4.03目标q 掌握建库的SQL语句q 掌握建表的SQL语句q 掌握加约束的SQL语句q 掌握创建安全帐户的SQL语句ACCP V4.04回顾数据库的基础知识q数据库文件的组成:q主数据文件:*.mdfq次要数据文件:*.ndfq日志文件:*.ldfq数据库的其他属性:q文件存放位置,分配的初始空间,属于哪个文件组q文件增长:可以按百分比或实际大小指定增长速度q文件容量设置:可以指定文件增长的最大值或不受限ACCP V4.0

2、5创建数据库 CREATE DATABASE 数据库名 ON PRIMARY ( ,n ) LOG ON ( ,n )T-SQL创建数据库的语法:主文件组,可选参数,默认ACCP V4.06创建数据库示例 1CREATE DATABASE stuDB ON PRIMARY -默认就属于PRIMARY主文件组,可省略( NAME=stuDB_data, -主数据文件的逻辑名 FILENAME=D:projectstuDB_data.mdf, -主数据文件的物理名 SIZE=5mb, -主数据文件初始大小 MAXSIZE=100mb, -主数据文件增长的最大值 FILEGROWTH=15% -主数

3、据文件的增长率)LOG ON( NAME=stuDB_log, FILENAME=D:projectstuDB_log.ldf, SIZE=2mb, FILEGROWTH=1MB)GO 数据文件的具体描述日志文件的具体描述演示创建数据库1:一个数据文件和一个日志文件 ACCP V4.07创建数据库示例 2CREATE DATABASE employees ON ( /*-主数据文件的具体描述-*/ NAME = employee1, FILENAME = D:projectemployee1_Data.mdf , SIZE = 10, FILEGROWTH = 10% ), ( /*-次要数据

4、文件的具体描述-*/ NAME = employee2, FILENAME = D:projectemployee2_Data.ndf , SIZE = 20, MAXSIZE = 100, FILEGROWTH = 1 ) LOG ON ( /*-日志文件1的具体描述-*/ NAME = employeelog1, FILENAME = D:projectemployeelog1_Log.ldf , SIZE = 10, FILEGROWTH = 1 ), ( /*-日志文件2的具体描述-*/ NAME = employeelog2, FILENAME = D:projectemployee

5、log2_Log.ldf , SIZE = 10, MAXSIZE = 50, FILEGROWTH = 1 )GO 演示创建数据库2:多个数据文件和多个日志文件 ACCP V4.08删除数据库q 如果SQL Server中已存在数据库stuDB,运行下列语句,会出现什么问题?CREATE DATABASE stuDBON (.)LOG ON(.)GO演示:再次运行示例1ACCP V4.09USE master -设置当前数据库为master,以便访问sysdatabases表GOIF EXISTS(SELECT * FROM sysdatabases WHERE name =stuDB) D

6、ROP DATABASE stuDBCREATE DATABASE stuDBON ( .)LOG ON( )GO删除数据库q删除数据库的语法:DROP DATABASE 数据库名 EXISTS()语句:检测是否存在stuDB数据库如果存在stuDB数据库,则删除 ACCP V4.010回顾表的基础知识 q 建表的基本步骤:q确定表中有哪些列q确定每列的数据类型q给表添加各种约束q创建各表之间的关系q SQL Server中的数据类型 整型数据:int smallint 浮点数据:float numeric字符数据固定长度:char(6)可变长度: varchar(10) unicode编码:

7、nchar(10) 布尔数据(真/假) bit: 1/ 0 货币数据 money日期数据 datetimeACCP V4.011创建表q建表的语法CREATE TABLE 表名 ( 字段1 数据类型 列的特征, 字段2 数据类型 列的特征, .)列的特征:包括该列是是否为空(NULL)、是否是标识列(自动编号)、是否有默认值、是否为主键等。 ACCP V4.012建表示例 1USE stuDB -将当前数据库设置为stuDB GOCREATE TABLE stuInfo /*-创建学员信息表-*/( stuName VARCHAR(20) NOT NULL , -姓名,非空(必填) stuNo

8、 CHAR(6) NOT NULL, -学号,非空(必填) stuAge INT NOT NULL, -年龄,INT类型默认为4个字节 stuID NUMERIC(18,0), -身份证号 stuSeat SMALLINT IDENTITY (1,1), -座位号,自动编号 stuAddress TEXT -住址,允许为空,即可选输入) GONUMERIC (18,0)代表18位数字,小数位数为0演示:创建学员信息表stuInfoIDENTITY(起始值,递增量) ACCP V4.013建表示例 2CREATE TABLE stuMarks( ExamNo CHAR(7) NOT NULL,

9、-考号 stuNo CHAR(6) NOT NULL, -学号 writtenExam INT NOT NULL, -笔试成绩 LabExam INT NOT NULL -机试成绩)GO演示:创建学员成绩表 stuMarksACCP V4.014删除表q 如果当前数据库中已存在stuInfo表,再次创建时系统将提示出错 。如何解决呢?ACCP V4.015删除表q删除表的语法:DROP TABLE 表名USE stuDB -将当前数据库设置为stuDB ,以便在stuDB数据库中建表GOIF EXISTS(SELECT * FROM sysobjects WHERE name=stuInfo

10、) DROP TABLE stuInfoCREATE TABLE stuInfo /*-创建学员信息表-*/(.) GOACCP V4.016回顾SQL Server的约束q 约束的目的:确保表中数据的完整型q 常用的约束类型:q主键约束(Primary Key Constraint):要求主键列数据唯一,并且不允许为空q唯一约束(Unique Constraint):要求该列唯一,允许为空,但只能出现一个空值。q检查约束(Check Constraint):某列取值范围限制、格式限制等,如有关年龄的约束q默认约束(Default Constraint):某列的默认值,如我们的男性学员较多,性

11、别默认为“男”q外键约束(Foreign Key Constraint):用于两表间建立关系,需要指定引用主表的那列ACCP V4.017添加约束 q 添加约束的语法:ALTER TABLE 表名 ADD CONSTRAINT 约束名 约束类型 具体的约束说明q 约束名的取名规则推荐采用:约束类型_约束字段q主键(Primary Key)约束:如 PK_stuNoq唯一(Unique Key)约束:如 UQ_stuIDq默认(Default Key)约束:如 DF_stuAddressq检查(Check Key)约束:如 CK_stuAgeq外键(Foreign Key)约束:如 FK_stu

12、No ACCP V4.018添加约束示例ALTER TABLE stuInfo ADD CONSTRAINT PK_stuNo PRIMARY KEY (stuNo)ALTER TABLE stuInfo ADD CONSTRAINT UQ_stuID UNIQUE (stuID)ALTER TABLE stuInfo ADD CONSTRAINT DF_stuAddress DEFAULT (地址不详) FOR stuAddressALTER TABLE stuInfo ADD CONSTRAINT CK_stuAge CHECK(stuAge BETWEEN 15 AND 40)ALTER

13、 TABLE stuMarks ADD CONSTRAINT FK_stuNo FOREIGN KEY(stuNo) REFERENCES stuInfo(stuNo)GO演示:给学员信息表stuInfo添加约束添加主键约束(stuNo作为主键)添加唯一约束(因为每人的身份证号全国唯一)添加默认约束(如果地址不填,默认为“地址不详”)添加检查check约束,要求年龄只能在1540岁之间添加外键约束(主表stuInfo和从表stuMarks建立关系,关联字段为stuNo)ACCP V4.019添加约束示例演示:查看约束结果ACCP V4.020删除约束q如果错误地添加了约束,我们还可以删除约束

14、q删除约束的语法ALTER TABLE 表名 DROP CONSTRAINT 约束名 例如:删除stuInfo表中地址默认约束ALTER TABLE stuInfo DROP CONSTRAINT DF_stuAddressACCP V4.021回顾SQL Server的安全模型数据库 1数据库 2数据库 3表 1表 2表 1表 2表 1表 2增删改查增删改查增删改查增删改查增删改查增删改查数据库用户数据库用户数据库用户登录帐号登录帐号SQLserver三层安全管理ACCP V4.022登录方式回顾q 登录验证有两种方式:qSQL身份验证:适合于非windows平台的用户或Internet用户

15、, 需要提供帐户和密码qWindows身份验证:适合于windows平台用户,不需要提供密码,和windows集成验证q 登录帐户相应有两种:SQL 帐户和Windows帐户 ACCP V4.023创建登录q添加 Windows登录帐户 EXEC sp_grantlogin jbtrainingS26301 q添加 SQL登录帐户 EXEC sp_addlogin zhangsan, 1234演示创建登录EXEC表示调用存储过程,存储过程类似C语言的函数内置的系统管理员 帐户sa密码默认为空,建议修改密码 域名用户名用户名,密码ACCP V4.024创建登录ACCP V4.025创建数据库用户

16、q 创建数据库用户需要调用系统存储过程sp_grantdbaccess,其用法为:EXEC sp_grantdbaccess 登录帐户名,数据库用户名 其中,“数据库用户“为可选参数,默认为登录帐户,即数据库用户默认和登录帐户同名。USE stuDBGOEXEC sp_grantdbaccess jbtrainingS26301, S26301DBUser EXEC sp_grantdbaccess zhangsan, zhangsanDBUser在stuDB数据库中添加两个用户ACCP V4.026创建数据库用户ACCP V4.027qdbo 用户q表示数据库的所有者(DB Owner)q无

17、法删除 dbo 用户,此用户始终出现在每个数据库中 qguest 用户q适用于没有数据库用户的登录帐号访问q每个数据库可有也可删除系统内置的数据库用户ACCP V4.028向数据库用户授权 EmployeesEmployeeID123LastNameDavolioFullerLeverling FirstName NancyAndrewJanetReportsTo22 .delete FROM EmployeesSELECT * FROM EmployeesACCP V4.029权限的类型 2-1q 授权的语法为:q GRANT 权限 ON 表名 TO 数据库用户USE stuDBGO/*-为zhangsanDBUser分配对表stuInfo的select, insert, update权限-*/GRANT select, insert, update ON stuInfo TO zhangsanDBUser /*-为S26301DBUser分配建表的权限-*/GRANT create table TO S263

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论