让SELECT查询结果额外增加自动递增序号的五种方法

/* 方法一*/
SELECT 序号= (SELECT COUNT(客户编号) FROM 客户 AS LiMing
                    WHERE LiMing.客户编号<= Chang.客户编号),
       客户编号, 公司名称
FROM 客户 AS Chang ORDER BY 1;
GO

/* 方法二: 使用SQL Server 2005 独有的RANK() OVER () 语法*/
SELECT RANK() OVER (ORDER BY 客户编号 DESC) AS 序号,
         客户编号, 公司名称
FROM 客户;
GO

/* 方法三*/
SELECT 序号= COUNT(*), LiMing.客户编号, LiMing.公司名称
   FROM 客户 AS LiMing, 客户AS Chang
   WHERE LiMing.客户编号>= Chang.客户编号
   GROUP BY LiMing.客户编号, LiMing.公司名称
   ORDER BY 序号;
GO

/* 方法四
建立一个「自动编号」的字段,然后将数据新增至一个区域性暂存数据表,
然后由该区域性暂存数据表中,将数据选取出来,最后删除该区域性暂存数据表
*/
SELECT 序号= IDENTITY(INT,1,1), 管道, 程序语言, 讲师, 资历
INTO #LiMing
FROM 问券调查一;
GO
SELECT * FROM #LiMing;
GO
DROP TABLE #LiMing;
GO

/*
方法五
使用 SQL Server 2005 独有的ROW_NUMBER() OVER () 语法
搭配 CTE (一般数据表表达式,就是 WITH 那段语法)选取序号2 ~ 4 的数据
*/
WITH 排序后的图书 AS
  (SELECT ROW_NUMBER() OVER (ORDER BY 客户编号 DESC) AS 序号,
   客户编号, 公司名称
   FROM 客户)
SELECT * FROM 排序后的图书
WHERE 序号 BETWEEN 2 AND 4;

了解数据库关系图所有权(“此数据库没有有效所有者”错误的解决方法)

若要在 SQL Server Management Studio 中安装数据库关系图支持,数据库必须处于 SQL Server 2005 数据库兼容级别。如果数据库未在 90 兼容级别,则在尝试安装关系图支持时出现以下错误:

此数据库没有有效所有者,因此无法安装数据库关系图支持对象。若要继续,请首先使用“数据库属性”对话框的“文件”页或 ALTER AUTHORIZATION 语句将数据库所有者设置为一个有效的登录名,然后添加数据库关系图支持对象。

安装关系图支持后,可重置数据库兼容级别。使用以下 Transact-SQL 语句更改数据库的兼容级别,然后重试数据库关系图操作。

EXEC sp_dbcmptlevel 'database_name', '90';

这些支持对象可能无法安装在已附加到其他 SQL Server 实例或通过其他实例还原的数据库中。如果数据库所有者名称(存储于数据库中)在数据库附加或还原到的 SQL Server 实例中不是有效的登录名,则可能会发生这种情况。

使用以下 Transact-SQL 语句将 SQL Server 实例中的数据库所有者改为有效的登录名,然后重试数据库关系图操作。

ALTER AUTHORIZATION ON DATABASE::database_name TO valid_login

Linq的LEFT JOIN和RIGHT JOIN方案

Linq只有join,就是inner join啦,只有用如下方案:

var result = from p in snsDC.NT_User
                         join q in snsDC.NT_Photo on p.Portrait equals q.PhotoID into pq
                         from r in pq.DefaultIfEmpty()
                         where userIDs.ToArray().Contains(p.UserID.ToString())
                         select new { p.UserID, p.UserName, r.FilePath };

Linq的Contains错误

今天用Linq的Contains实现SQL下(WHERE...IN)语句,有如下错误:
“方法“Boolean Contains(System.Guid)”不支持转换为 SQL。”

源代码如下:
var result = from p in snsDC.NT_User
                         join q in snsDC.NT_Photo on p.Portrait equals q.PhotoID into pq
                         from r in pq.DefaultIfEmpty()
                         where userIDs.Contains(p.UserID.ToString())
                         select new { p.UserID, p.UserName, r.FilePath };

分析:
估计是Linq无法将IList的Contains方法正确翻译为SQL语句。

改为:
var result = from p in snsDC.NT_User
                         join q in snsDC.NT_Photo on p.Portrait equals q.PhotoID into pq
                         from r in pq.DefaultIfEmpty()
                         where userIDs.ToArray().Contains(p.UserID.ToString())
                         select new { p.UserID, p.UserName, r.FilePath };