- 1、本文档共39页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第二章 数据库的实现 目标 掌握建库的SQL语句 掌握建表的SQL语句 回顾数据库的基础知识 创建数据库 创建数据库示例 1 创建数据库示例 2 删除数据库 如果SQL Server中已存在数据库stuDB,运行下列语句,会出现什么问题? 删除数据库 删除数据库的语法: 修改数据库 修改数据库的语法 修改数据库示例 回顾表的基础知识 SQL Server的数据类型 创建表 建表的语法 建表示例 1 建表示例 2 删除表 如果当前数据库中已存在stuInfo表,再次创建时系统将提示出错 。如何解决呢? 删除表 删除表的语法: SQL Server的约束 约束的目的:确保表中数据的完整型 常用的约束类型: 主键约束(Primary Key Constraint):要求主键列数据唯一,并且不允许为空 唯一约束(Unique Constraint):要求该列唯一,允许为空,但只能出现一个空值。 检查约束(Check Constraint):某列取值范围限制、格式限制等,如有关年龄的约束 默认约束(Default Constraint):某列的默认值,如我们的男性学员较多,性别默认为“男” 外键约束(Foreign Key Constraint):用于两表间建立关系,需要指定引用主表的那列 添加约束 添加约束的语法: 添加约束示例 添加约束示例 删除约束 如果错误地添加了约束,我们还可以删除约束 删除约束的语法 表的数据操作 向表中插入数据语法 用UPDATE语句修改表数据 用DELETE语句删除表中数据 思考 关系图 登录方式回顾 登录验证有两种方式: SQL身份验证:适合于非windows平台的用户或Internet用户, 需要提供帐户和密码 Windows身份验证:适合于windows平台用户,不需要提供密码,和windows集成验证 登录帐户相应有两种:SQL 帐户和Windows帐户 创建登录 添加 Windows登录帐户 EXEC sp_grantlogin ‘jbtraining\S26301‘ 添加 SQL登录帐户 EXEC sp_addlogin ‘zhangsan, ‘1234’ 创建登录 创建数据库用户 创建数据库用户需要调用系统存储过程sp_grantdbaccess,其用法为: 创建数据库用户 向数据库用户授权 权限的类型 2-1 授权的语法为: GRANT 权限 [ON 表名 ] TO 数据库用户 权限的类型 2-2 总结 2-1 数据库的物理实现一般包括: 创建数据库 创建表 添加各种约束 创建数据库的登录帐户并授权 创建数据库或表时一般需要预先检测是否存在该对象 数据库从master系统数据库的sysdatabases表中查询 表从该数据库的系统表sysobjects表中查询 总结 2-2 访问SQL Server某个数据库中的某个表,需要三层验证: 是否是SQL Server的登录帐户 是否是该数据库的用户 是否有足够的权限访问该表 EXEC sp_grantdbaccess ‘登录帐户名’,’数据库用户名’ 其中,“数据库用户“为可选参数,默认为登录帐户, 即数据库用户默认和登录帐户同名。 USE stuDB GO EXEC sp_grantdbaccess jbtraining\S26301, S26301DBUser EXEC sp_grantdbaccess zhangsan, zhangsanDBUser 在stuDB数据库中添加两个用户 dbo 用户 表示数据库的所有者(DB Owner) 无法删除 dbo 用户,此用户始终出现在每个数据库中 guest 用户 适用于没有数据库用户的登录帐号访问 每个数据库可有也可删除 系统内置的数据库用户 Employees EmployeeID 1 2 3 LastName Davolio Fuller Leverling FirstName Nancy Andrew Janet ReportsTo 2 2 ... delete FROM Employees SELECT * FROM Employees USE stuDB GO /*--为zhangsanDBUser分配对表stuInfo的select, insert, update权限--*/ GRANT select, insert, update ON stuInfo TO zhangsanDBUser /*--为S26301DBUser分配建表的权限--*/ GRANT create table TO S263
文档评论(0)