仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 1111|回复: 7
打印 上一主题 下一主题

[学习教程] MSSQL网页编程之T-SQL,静态聚合查询

[复制链接]
金色的骷髅 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-1-16 22:40:30 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
MySQL的海豚标志的名字叫“sakila”,它是由MySQLAB的创始人从用户在“海豚命名”的竞赛中建议的大量的名字表中选出的。获胜的名字是由来自非洲斯威士兰的开源软件开发者AmbroseTwebaze提供。静态
IFEXISTS(SELECTTABLE_NAMEFROMINFORMATION_SCHEMA.TABLESWHERETABLE_NAME=AccountMessage)DROPTABLEAccountMessageGO

CREATETABLEAccountMessage(FFundCodeVARCHAR(6)NOTNULL,FAccNameVARCHAR(20)NOTNULL,FAccNumINTNOTNULL);

IFEXISTS(SELECTTABLE_NAMEFROMINFORMATION_SCHEMA.TABLESWHERETABLE_NAME=AccountBalance)DROPTABLEAccountBalanceGO

CREATETABLEAccountBalance(FFundCodeVARCHAR(6)NOTNULL,FAccNumINTNOTNULL,FDateDATETIMEDEFAULT(getdate())NOTNULL,FBalNUMERIC(10,2)NOTNULL);

INSERTINTOAccountMessageVALUES(000001,北京存款,1)INSERTINTOAccountMessageVALUES(000001,上海存款,2)INSERTINTOAccountMessageVALUES(000001,深圳存款,3)INSERTINTOAccountMessageVALUES(000002,北京存款,1)INSERTINTOAccountMessageVALUES(000002,上海存款,2)INSERTINTOAccountMessageVALUES(000002,天津存款,3)INSERTINTOAccountMessageVALUES(000003,上海存款,1)INSERTINTOAccountMessageVALUES(000003,福州存款,2)

INSERTINTOAccountBalance(FDate,FFundCode,FAccNum,FBal)VALUES(2004-07-28,000001,1,1000.00)INSERTINTOAccountBalance(FDate,FFundCode,FAccNum,FBal)VALUES(2004-07-28,000001,2,1000.00)INSERTINTOAccountBalance(FDate,FFundCode,FAccNum,FBal)VALUES(2004-07-28,000001,3,1120.00)INSERTINTOAccountBalance(FDate,FFundCode,FAccNum,FBal)VALUES(2004-07-28,000002,1,2000.00)INSERTINTOAccountBalance(FDate,FFundCode,FAccNum,FBal)VALUES(2004-07-28,000002,2,1000.00)INSERTINTOAccountBalance(FDate,FFundCode,FAccNum,FBal)VALUES(2004-07-28,000002,3,1000.00)INSERTINTOAccountBalance(FDate,FFundCode,FAccNum,FBal)VALUES(2004-07-28,000003,1,2000.00)INSERTINTOAccountBalance(FDate,FFundCode,FAccNum,FBal)VALUES(2004-07-28,000003,2,1000.00)go

两种分歧的办法

declare@snvarchar(4000)set@s=select@s=@s+,+quotename(FAccName)+=isnull(sum(casea.FAccNamewhen+quotename(FAccName,)+thenb.FBalend),0)fromAccountMessagegroupbyFAccNameexec(select基金代码=a.FFundCode+@s+fromAccountMessagea,AccountBalancebwherea.FFundCode=b.FFundCodeanda.FAccNum=b.FAccNumgroupbya.FFundCode)go

select*into#tfrom(selecta.*,b.fbalfromAccountMessageajoinAccountBalancebona.ffundcode=b.ffundcodeanda.faccnum=b.faccnum)tDECLARE@SQLVARCHAR(8000)SET@SQL=SELECTffundcodeSELECT@SQL=@SQL+,sum(CASEWHENFAccName=+tt+THENFBalelse0END)[+tt+]FROM(SELECTDISTINCTFAccNameasttFROM#t)ASET@SQL=@SQL+FROM#tgroupbyffundcodeexec(@SQL)
有了rowbase的binlog后,我们来分析一下怎么实现闪回。平时的DML无非三种操作,增删改,先说三种操作的日志格式。
再见西城 该用户已被删除
沙发
发表于 2015-1-19 21:10:27 | 只看该作者
索引视图2k就有。但是2005对其效率作了一些改进但是schema.viewname的作用域真是太限制了它的应用面。还有一大堆的环境参数和种种限制都让人对它有点却步。
莫相离 该用户已被删除
板凳
发表于 2015-2-4 20:31:48 | 只看该作者
如果你是从“学习某一种数据库应用软件,从而获得应聘的资本和工作机会”的角度来问的话。
若相依 该用户已被删除
地板
发表于 2015-2-10 07:50:19 | 只看该作者
我是新手,正在学习数据库和操作系统,深感理论的泛广,唯有一步一步来,但是又感觉时间不够,收集了很多资料却总是没能认真的看完,希望有一个讨论板块,大家共同解决,共同分享,共同努力
小女巫 该用户已被删除
5#
发表于 2015-3-1 03:35:19 | 只看该作者
习惯敲命令行的朋友可能会爽一些。但是功能有限。适合机器跑不动SQLServerManagementStudio的朋友使用。
变相怪杰 该用户已被删除
6#
发表于 2015-3-10 12:43:10 | 只看该作者
比如,MicrosoftSQLServer2008的某一个版本可以满足现在的这个业务的需要,而且价格还比Oracle11g要便宜,那么这一产品就是适合的。
活着的死人 该用户已被删除
7#
发表于 2015-3-17 07:08:35 | 只看该作者
索引视图2k就有。但是2005对其效率作了一些改进但是schema.viewname的作用域真是太限制了它的应用面。还有一大堆的环境参数和种种限制都让人对它有点却步。
因胸联盟 该用户已被删除
8#
发表于 2015-3-24 00:58:01 | 只看该作者
另一个是把SQL语句写到服务器端,就是所谓的SP(存储过程);
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-12-22 18:02

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表