电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

如何使用SQL Server數據庫查詢累計值

瀏覽:148日期:2023-11-06 17:15:19

有這樣一個要求,它要創建一個SQL Server查詢,其中包括基于事件時刻的累計值。典型的例子就是一個銀行賬戶,因為你每一次都是在不同的時間去存錢和取錢。對任意一個賬戶來說,在某個時間點都要算出它的借(存款)和貸(取款)之和。每一筆交易之后,你都想知道當前的余額。列表A創建了這樣一個表格的簡單的例子。

CREATETABLE [dbo].[BankAccount]([TransactionID] [int] IDENTITY(1,1)NOTNULL,[TransactionDateTime] [datetime] NOTNULLCONSTRAINT[DF_BankAccount_TransactionDateTime]; DEFAULT(getdate()),[Amount] [money] NOTNULLCONSTRAINT [DF_BankAccount_Amount]; DEFAULT((0)),[TransactionType] [char](1)COLLATE SQL_Latin1_General_CP1_CI_AS NOTNULL,[AccountNumber] [varchar](50)COLLATE SQL_Latin1_General_CP1_CI_AS NULL,CONSTRAINT [PK_BankAccount] PRIMARYKEYCLUSTERED ( [TransactionID] ASC)WITH(PAD_INDEX; =OFF, IGNORE_DUP_KEY =OFF)ON [PRIMARY])ON [PRIMARY]

列表A下面是一些示例行:

1;;2006-11-03 02:33:42.34010000.002;;2006-11-03 02:34:50.467-500.003;;2006-11-03 02:35:04.857250.004;;2006-11-03 02:42:19.763-124.25

因為日期是缺省設定的,你要做的就是加入一些金額。例子中為了簡單起見,假設只有一個銀行賬戶(為了更符合實際情況,可以添加一個BankAccountNumber列)。

現在你就能夠創建一個包括了當前余額的查詢。因為你已經在同一列中用正負數值記錄了存款和取款值,所以列中的累計值是很容易算出的。你要得到當前的余額,就要計算出以前所有交易的總值,然后將這個值和當前的交易相加。列表B中的查詢實現了這一點。

SELECT transactionid, transactiondatetime, amount,

(SELECT SUM(amount)

FROM dbo.bankaccount as D1

WHERE D1.transactiondatetime <= D0.transactiondatetime) AS balance

FROM dbo.bankaccount AS D0

列表B這樣就得到了以下的結果集:

1;;2006-11-03 02:33:42.34010000.00;10000.002;;2006-11-03 02:34:50.467-500.00;;9500.003;;2006-11-03 02:35:04.857250.00;;;9750.004;;2006-11-03 02:42:19.763-124.25;;9625.75

如這個例子所示,只要你理解了要求,就可以很容易地建立累計值。所示的例子假設表格中只包括一個賬戶,但是要處理多個賬戶也很簡單。添加一個BankAccountNumber 列和一個指定利息數量的WHERE謂詞即可。

你也可以把這個例子倒過來用,如在一個存貨計算中創建一個不同的運行。你從存貨1,000開始,然后減去各種花銷和收據。

這樣的查詢有兩個優點:

● 你不需要儲存結果。當用賬戶編號或外鍵操作時,執行可以如閃電般迅速。

● 你以一個標簽結束事務,它可以逐行進行檢查。如果出現問題的話,你可以將導致問題出現的事務隔離。

標簽: Sql Server 數據庫
主站蜘蛛池模板: 预制直埋蒸汽保温管-直埋管道-聚氨酯发泡保温管厂家 - 唐山市吉祥保温工贸有限公司 | PU树脂_水性聚氨酯树脂_聚氨酯固化剂_聚氨酯树脂厂家_宝景化工 | 飞扬动力官网-广告公司管理软件,广告公司管理系统,喷绘写真条幅制作管理软件,广告公司ERP系统 | 塑料熔指仪-塑料熔融指数仪-熔体流动速率试验机-广东宏拓仪器科技有限公司 | 包塑软管|金属软管|包塑金属软管-闵彬管业 | 保温杯,儿童婴童奶瓶,运动水壶「广告礼品杯定制厂家」超朗保温杯壶 | 加热制冷恒温循环器-加热制冷循环油浴-杭州庚雨仪器有限公司 | 右手官网|右手工业设计|外观设计公司|工业设计公司|产品创新设计|医疗产品结构设计|EMC产品结构设计 | 细沙回收机-尾矿干排脱水筛设备-泥石分离机-建筑垃圾分拣机厂家-青州冠诚重工机械有限公司 | [品牌官网]贵州遵义双宁口腔连锁_贵州遵义牙科医院哪家好_种植牙_牙齿矫正_原华美口腔 | 美的商用净水器_美的直饮机_一级代理经销商_Midea租赁价格-厂家反渗透滤芯-直饮水批发品牌售后 | 比亚迪叉车-比亚迪电动叉车堆垛车托盘车仓储叉车价格多少钱报价 磁力去毛刺机_去毛刺磁力抛光机_磁力光饰机_磁力滚抛机_精密金属零件去毛刺机厂家-冠古科技 | 北京办公室装修,办公室设计,写字楼装修-北京金视觉装饰工程公司 北京成考网-北京成人高考网 | 聚天冬氨酸,亚氨基二琥珀酸四钠,PASP,IDS - 远联化工 | 首页|光催化反应器_平行反应仪_光化学反应仪-北京普林塞斯科技有限公司 | 郑州水质检测中心_井水检测_河南废气检测_河南中环嘉创检测 | 东莞办公家具厂家直销-美鑫【免费3D效果图】全国办公桌/会议桌定制 | 高压分散机(高压细胞破碎仪)百科-北京天恩瀚拓 | 房车价格_依维柯/大通/东风御风/福特全顺/江铃图片_云梯搬家车厂家-程力专用汽车股份有限公司 | 南京兰江泵业有限公司-水解酸化池潜水搅拌机-絮凝反应池搅拌机-好氧区潜水推进器 | 深圳彩钢板_彩钢瓦_岩棉板_夹芯板_防火复合彩钢板_长鑫 | 蒸汽热收缩机_蒸汽发生器_塑封机_包膜机_封切收缩机_热收缩包装机_真空机_全自动打包机_捆扎机_封箱机-东莞市中堡智能科技有限公司 | 手术室净化厂家-成都做医院净化工程的公司-四川华锐-15年特殊科室建设经验 | PC构件-PC预制构件-构件设计-建筑预制构件-PC构件厂-锦萧新材料科技(浙江)股份有限公司 | 南方珠江-南方一线电缆-南方珠江科技电缆-南方珠江科技有限公司 南汇8424西瓜_南汇玉菇甜瓜-南汇水蜜桃价格 | 睿婕轻钢别墅_钢结构别墅_厂家设计施工报价 | 欧美日韩国产一区二区三区不_久久久久国产精品无码不卡_亚洲欧洲美洲无码精品AV_精品一区美女视频_日韩黄色性爱一级视频_日本五十路人妻斩_国产99视频免费精品是看4_亚洲中文字幕无码一二三四区_国产小萍萍挤奶喷奶水_亚洲另类精品无码在线一区 | 电子书导航网_电子书之家_电子书大全_最新电子书分享发布平台 | 购买舔盐、舔砖、矿物质盐压块机,鱼饵、鱼饲料压块机--请到杜甫机械 | 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库-首页-东莞市傲马网络科技有限公司 | 120kv/2mA直流高压发生器-60kv/2mA-30kva/50kv工频耐压试验装置-旭明电工 | 石家庄网站建设|石家庄网站制作|石家庄小程序开发|石家庄微信开发|网站建设公司|网站制作公司|微信小程序开发|手机APP开发|软件开发 | 粉末冶金-粉末冶金齿轮-粉末冶金零件厂家-东莞市正朗精密金属零件有限公司 | 仿真茅草_人造茅草瓦价格_仿真茅草厂家_仿真茅草供应-深圳市科佰工贸有限公司 | 钢格板|热镀锌钢格板|钢格栅板|钢格栅|格栅板-安平县昊泽丝网制品有限公司 | 根系分析仪,大米外观品质检测仪,考种仪,藻类鉴定计数仪,叶面积仪,菌落计数仪,抑菌圈测量仪,抗生素效价测定仪,植物表型仪,冠层分析仪-杭州万深检测仪器网 | 定制奶茶纸杯_定制豆浆杯_广东纸杯厂_[绿保佳]一家专业生产纸杯碗的厂家 | 广西绿桂涂料--承接隔热涂料、隔音涂料、真石漆、多彩仿石漆等涂料工程双包施工 | 厂房出售_厂房仓库出租_写字楼招租_土地出售-中苣招商网-中苣招商网 | CE认证_FCC认证_CCC认证_MFI认证_UN38.3认证-微测检测 CNAS实验室 | 厚壁钢管-厚壁无缝钢管-小口径厚壁钢管-大口径厚壁钢管 - 聊城宽达钢管有限公司 |