问:我的microsoft access 2000应用程序由后端的sql server 2000数据库写入数据。为防止access的用户看到sql server 2000表中的全部数据,我想使用一种只允许用户浏览授权数据行的视图。可以创建一种限制用户访问sql server数据的视图吗?
答:可以。如果每位用户以唯一的用户id登录到access,您就可以创建一种限制用户访问sql server数据的视图。以下的示例语句就可以创建这样一种视图:
create view v_data as
select <column_list>
from dbo.mytable as a
inner join dbo.authtable as b
on (a.pkey = b.datakey
and b.userid = suser_sname())
该视图按userid限制用户的访问权。它要求您保存一份与数据表(mytable)中特定主键相匹配的用户名的表(authtable)。如果您的情况相对比较简单——您无需管理多个用户的行访问权,则您可以将userid列插入到数据表中,如下列代码所示:
create view v_data as
select <column_list>
from dbo.mytable as a
where a.userid = suser_sname()
—microsoft sql server 开发团队
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 注册表 操作系统 服务器 应用服务器