server2005扩充技巧

转载 2007年09月13日 22:11:00
实例:用SQLServer2005内置工具建立审查系统:能够得到,如谁访问了我们的数据、如何批准访问权、以及我们如何对访问进行监控,以防止某些人入侵、登录数据或做他们不该做的事情。引用这里


在SQL2005中处理交叉表: 关键字:
PIVOT 和 UNPIVOT
示例:
DECLARE @t TABLE ([日期] datetime,[时间] varchar(20),[售货金额] int)
insert into @t select '2006-01-02','早上',50
union all select '2006-01-02','中午',20
union all select '2006-01-02','晚上',30
union all select '2006-01-02','零晨',40
union all select '2006-01-03','早上',40
union all select '2006-01-03','中午',60
union all select '2006-01-03','晚上',50
union all select '2006-01-03','零晨',50
union all select '2006-01-04','早上',80
union all select '2006-01-04','中午',60
union all select '2006-01-04','晚上',20
union all select '2006-01-04','零晨',40
--查询
select * ,金额小计=(select sum(售货金额) from @t where 日期=PT.日期 ) from @t as TAB
PIVOT
max([售货金额])
  
for [时间] in ([早上],[中午],[晚上],[零晨])
as PT
--列不确定时:
DECLARE @S VARCHAR(MAX)
SET @S=''
SELECT @S=@S+',['+时间+']' FROM @t
  
GROUP BY 时间
SET @S=STUFF(@S,1,1,'')
EXEC('
select 日期,
'+@S+',金额小计=(select sum(售货金额) from @t where 日期=PT.日期 ) from @t as TAB
PIVOT
( max(售货金额)
  for 时间 in (
'+@S+')
) as PT
')


SQL2005中拆分列值
,借用XML,简单。见示例:
-- 示例数据
DECLARE @t TABLE(id int[values] varchar(100))
INSERT @t SELECT 1'aa,bb'
UNION ALL SELECT 2'aaa,bbb,ccc'

-- 查询处理
SELECT A.id, B.value
FROM(
SELECT id, [values] = CONVERT(xml,
'<root><v>' + REPLACE([values]',''</v><v>'+ '</v></root>')
FROM @t
)A
OUTER APPLY(
SELECT value = N.v.value('.''varchar(100)')
FROM A.[values].nodes('/root/v') N(v)
)B
结果:
1    aa
1    bb
2    aaa
2    bbb
2    ccc
引用 :http://blog.csdn.net/itblog/archive/2006/06/05/774358.aspx

SQL2005中合并列值,见示例
-- 示例数据
DECLARE @t TABLE(id int, value varchar(10))
INSERT @t 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(
SELECT DISTINCT
id
FROM @t
)A
OUTER APPLY(
SELECT [values]= STUFF(REPLACE(REPLACE(
(
SELECT value FROM @t N
WHERE id = A.id
FOR XML AUTO
), 
'<N value="'','), '"/>'''), 11'')
)N

/**//*--结果
id          values
----------- ----------------
1           aa,bb
2           aaa,bbb,ccc
更多见:http://blog.csdn.net/itblog/archive/2006/06/05/774363.aspx


SQL2005新函数,排列函数
示例1: 在结果集中显示行号 ROW_NUMBER ( )函数 语法:
ROW_NUMBER() OVER ( [ <partition_by_clause> ] <order_by_clause> )
SELECT ROW_NUMBER() OVER (ORDER BY id) AS 行号,* FROM sysobjects
返回结果集:
行号 对象名称  
1      sp_MSalreadyhavegeneration
2      sp_MSwritemergeperfcounter   
3      TABLE_PRIVILEGES 

在2000版本中要这样实现
SELECT Identity(int,1,1AS Num,* INTO #temptable FROM TableName 
SELECTFROM #temptable
DROP TABLE #temptable

示例2RANK()函数保留列表中行的位置序号,对于每个重复值,这个函数跳过下面值,于是下一个不重复的值就保留在了正确的位置上了。
DENSE_RANK()函数工作方式是相同的,不过它不跳过每个连带之后的数字,这样就不会有数字消失了,不过排列序号位置出现连带的地方就丢失了。
举例(在做学生成绩排名之类的时非常有作用。这两个非常有用)

示例3NTITLE(n)函数,将结果切分为有限数量的排列组。更多示例见联机丛书.


sql 2005 express版本,需要加增加图形管理器,下载,express版本中默认没有,sql2005 功能包 列表  
sql2005导入导出向导: C:/Program Files/Microsoft SQL Server/90/DTS/Binn/DTSWizard.exe 可自己在工具--外部工具中--添加引用.好比快捷方式。 
 

相关文章推荐

SQL Server技巧合集2005-04-2

SQL SERVER中对查询结果随机排序问:怎样才能对查询结果随机排序?   答:对结果记录随机排序,或随机返回X条记录,可以通过在SELECT语句中使用RAND函数来实现。但是RAND函数在查询中...

Sql Server 2005 专用管理员连接 (DAC) 使用技巧__收藏

1 什么是专用管理员连接? SQL Server 2005 为管理员提供了一种特殊的诊断连接,以供在无法与服务器建立标准连接时使用。 2 专用管理员连接有什么用? 即使在 SQL Server ...

dot NET SQL server2005使用技巧和示例

  • 2008年10月07日 09:42
  • 3.66MB
  • 下载

【SQL Server】SQL2005的安装与配置、简单使用

印象中,以前电脑不发达,自身编程经历不多的时候,由于Microsoft SQL Server版本众多,在不同版本的windows下必须要求装相应版本的SQL Server,否则有可能出现兼容性的问题,...

JDBC连接SQL_Server_2005数据库的方法

本文先介绍Windows XP SP2/SP3 下Microsoft SQL Server 2005 的安装及有关问题的解决方法,然后介绍Eclipse3.2 / 3.3 或 MyEclip...

SQL Server 2005 查看数据库表的大小 按照表大小排列

(1)Question:尼玛一个数据库,动辄几十个G,伤不起啊,怎样才能知道当前数据库里面各个表的大小呢?以便将部分较大的数据库表中不容易被频繁访问的数据归档到历史表中,例如每天将一个自然年以前的数据...

SQL Server 2005 扫描计数产生原因分析

http://www.cnblogs.com/zping/archive/2008/07/22/1249038.html 在上次做分页分析是分析时,执行下面语句: SELECT TOP 1...

如何修改SQL Server 2005/2008新建数据库文件及备份文件的默认保存路径

在SQL Server中,默认情况下,我们新建的数据库保存地址为C:\Program Files\Microsoft SQL Server\MSSQL.1\MSSQL\Data(这里以SQL Se...

SQL Server 2005 的版本和组件

更新日期: 2006 年 4 月 14 日 根据应用程序的需要,安装要求可能有很大不同。SQL Server 2005 的不同版本能够满足企业和个人独特的性能、运行时以及价格要求。需要安装哪些 ...

郝斌老师-sql-server-2005数据库大纲

声明:这是郝斌先生的笔记,我在博客中展示,只是为了方便查阅数据库学习大纲 什么是数据库 狭义: 存储数据的仓库 广义: 可以对数据进行存储和管理的软件以及数据本身统称为数据库...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:server2005扩充技巧
举报原因:
原因补充:

(最多只允许输入30个字)