易截截图软件、单文件、免安装、纯绿色、仅160KB

在SQL SERVER 2005/2008中拥有一个对象

在SQL SERVER 2005/2008中拥有一个对象
从SQL SERVER2000升级到2005/2008后,一个我们必须重新认识的情况是对象不再有所有者(owner)。架构包含对象,架构有所有者。如果你查询表sys.objects,你将会看到这看起来是正确的,只是表中还有一个字段principal_id,但是一般情况下它总是NULL值。不久前一天,我突然对principal_id字段的表示了疑惑:为什么要存在这个字段呢?我又仔细地看了联机帮助sys.objects的解释:
“如果不是架构所有者,则为单个所有者的 ID。默认情况下,架构包含的对象由架构所有者拥有。不过,通过使用 ALTER AUTHORIZATION 语句更改所有权可以指定备用所有者。”
换句话说,对象现在还可以被一个用户所拥有。但是“备用所有者”又让我打住了,这什么意思呢?让我们先建立一个测试环境:我们需要在两个不同架构中创建两个对象。这些架构属于不同的所有者,当然我们还需要一个测试者,所以还需要一个第三者。让我们搭起这个环境吧:
CREATE USER User1 WITHOUT LOGIN;
GO
CREATE USER User2 WITHOUT LOGIN;
GO
CREATE USER User3 WITHOUT LOGIN;
GO
/* 创建两个架构,并让它属于不同的用户*/
CREATE SCHEMA User1 AUTHORIZATION User1;
GO
CREATE SCHEMA User2 AUTHORIZATION User2;
GO
/* 核查一下架构,看它是否被不同架构所拥有*/
SELECT schema_id, [name], USER_NAME(principal_id) [Owner]
from sys.schemas
WHERE LEFT([name], 4) = 'User';
GO
现在我们已经有了用户和架构,我们再创建一个表和一个引用该表的存储过程。这两个对象分属不同的架构。这就是说没有形成所有权链。
/* 在user1架构上创建一个表。*/
CREATE TABLE User1.MyTable (Number INT);
GO
INSERT INTO User1.MyTable (Number) VALUES (1);
INSERT INTO User1.MyTable (Number) VALUES (2);
INSERT INTO User1.MyTable (Number) VALUES (3);
GO
/* 在user2架构中创建一个存储过程。因为user1和user2这两个架构属于不同的用户,所以不能形成所有权链。*/
CREATE PROC User2.MyProc
AS
BEGIN
  SELECT Number from User1.MyTable;
END;
GO
/* 授权我们的试验用户user3执行存储过程的能力。除此之外,user3没有任何权利,尤其是在user1.MyTable没有权利 */
GRANT EXECUTE ON OBJECT::User2.MyProc TO User3;
GO
/* 核查一下我们刚刚创建的架构和对象和&ldq


相关文档:

在c#中的取得sql存储过程的output参数

一直没有找到一种好的方法来引用有返回值的存储过程的方法,使我在添加数据中走了不少的弯路,最近,在查阅了大量的资料之后,终于在微软的一个实例中找到了一种良好的方法。
首先编写好一有返回值的存储过程
create procedure proc_name
   @para1 nchar(20),    --输入参数
   @ ......

实现多行合并一行的SQL [MSSQL2005]写法

--1. 创建表,添加测试数据
CREATE TABLE tb(id int, [value] varchar(10))
INSERT tb SELECT 1, 'aa'
UNION ALL SELECT 1, 'bb'
UNION ALL SELECT 2, 'aaa'
UNION ALL SELECT 2, 'bbb'
UNION ALL SELECT 2, 'ccc'
--SELECT * from tb
/**//*
id value
----------- ----------
1 aa
1 bb
2 aaa ......

简单的SQL面试题

1. Q. What is a join?
   A. Join is a process of retrieve pieces of data from different sets (tables) and returns them to the user or program as one joined collection of data.
2. Q. Can a table have more than one foreign key defined?
   A. A table can have any number of foreig ......

sql查询汇总

-
处理表重复记录(查询和删除)
/*
*****************************************************************************************************************************************************
1、Num、Name相同的重复值记录,没有大小关系只保留一条
2、Name相同,ID有大小关系时,保留大或小其中一个记录
整理人:中 ......

在VB2008 速成版中使用参数化SQL查询语句无效

  最近刚学会在VB2008 中使用参数化SQL语句,于是马上用到代码中,却碰到查不到任何数据的情况,纠结了好几天,还是没有搞明白,差点吐血。不得已还是先在代码中使用字符串拼接的SQL语句。
  包含参数化SQL语句的代码如下:
            Dim cmSl As N ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号