14.3.1 数据库用户简介
数据库用户用来指出哪一个人可以访问哪一个数据库。在一个数据库中,用户id惟一标识一个用户,用户对数据的访问权限以及对数据库对象的所有关系都是通过用户账号来控制的,用户账号总是基于数据库的,即两个不同数据库中可以有两个相同的用户账号。
在数据库中,用户账号与登录账号是两个不同的概念。一个合法的登录账号只表明该账号通过了nt 认证或sql server 认证,但不能表明其可以对数据库数据和数据对象进行某种或某些操作,所以一个登录账号总是与一个或多个数据库用户账号(这些账号必须分别存在相异的数据库中)相对应,这样才可以访问数据库。例如,登录账号sa 自动与每一个数据库用户dbo 相关联。
通常而言,数据库用户账号总是与某一登录账号相关联,但有一个例外,那就是guest用户。
在安装系统时,guest 用户被加入到master、 pubs、 tempdb 和northwind 数据中,那么sql server 为什么要进行这样的处理呢?让我们看看在用户通过nt 认证或sqlserver 认证而成功登录到sql server 之后,sql server 又做了哪些事情:
注意:通常我们可以像删除或添加其它有户那样删除或添加guest用户,但不能从master或tempdb数据库中删除该用户,并且在一个新建的数据库中不存在guest用户,除非将其添加进行。
14.3.2 管理数据库用户
1 利用sql server enterprise manager管理数据库用户
创建新数据库用户利用sql server enterprise manager 创建一个新数据库用户要执行以下步骤:
(1) 启动sql server enterprisemanager, 单击登录服务器旁边的‘+’标志。
(2) 打开database 文件夹,打开要创建用户的数据库。
(3) 右击user 图标,在弹出菜单中选择new database user, 弹出newdatabase user – new user 对话框。如图14-3 所示。
(4) 在login 选择框内选择已经创建的登录账号、在user 选择框内输入数据库用户名称。
(5)在database role membership 下的选项框中为该用户选择数据库角色(关于数据库角色将在角色一节中作详细介绍)。
(6)单击确定按钮。
当然,在创建一个sql server 登录账号时,就可以先为该登录账号定出其在不同数据库中所使用的用户名称,这实际上也完成了创建新的数据库用户这一任务。其操作步骤见“14.2.1使用sql server enterprise manager 管理sqlserver 登录”。 在打开的sql server properties – new login 对话框中选择database access标签页。见图14-4 所示。
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器