博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
游标之数据排序
阅读量:6003 次
发布时间:2019-06-20

本文共 3058 字,大约阅读时间需要 10 分钟。

由于在写“协同平台”要将主、细表的里内容在一个里进有序排序,本人认为最好用存储过程来实现,这样可以提高客户端的浏览速度         ^_^
None.gif
CREATE
            
PROCEDURE
 Aipetech_sp_PoOrderExeStatus
None.gif
@InterID
 
int
None.gif 
AS
None.gif
--
创建一个临时表,用来生成"未完采购订单的执行情况"
None.gif
None.gif
Create
 
Table
 #Aipetech_T002
None.gif    (
None.gif    采购订单内码 
int
,
None.gif    分录号 
int
,
None.gif    物料内码 
int
,
None.gif    物料编码 
varchar
(
80
),
None.gif    物料名称 
varchar
(
80
),
None.gif    收货日期 
datetime
,
None.gif    入库单号 
varchar
(
80
),
None.gif    单位 
varchar
(
30
),
None.gif    数量 
decimal
(
13
),
None.gif    入库数量 
decimal
(
13
default
 
0
,
None.gif    未完成数量 
decimal
(
13
default
 
0
,
None.gif    交货日期 
datetime
,
None.gif    备注 
varchar
(
255
)
None.gif    )
None.gif
None.gif
insert
 
into
 #Aipetech_T002
None.gif            (采购订单内码,分录号,物料内码,物料编码,物料名称,单位,数量,交货日期,备注)
None.gif            
select
 采购订单内码,分录号,物料内码,物料编码,物料名称,单位,数量,交货日期,备注 
from
 Aipetech_v_PoOrderEntry 
where
 采购订单内码
=
@InterID
None.gif
--
select * from #Aipetech_T002
None.gif
Create
 
Table
 #Aipetech_T003
None.gif    (
None.gif    采购订单内码 
int
,    
None.gif    物料内码 
int
,
None.gif    入库数量 
int
)
None.gif
None.gif
insert
 
into
 #Aipetech_T003
None.gif    (采购订单内码,物料内码,入库数量)
None.gif
select
 采购订单内码,物料内码,
sum
(辅助实收数量) 
as
 辅助实收数量   
from
 aipetech_v_icstockbill 
where
 ((采购订单内码
=
@InterID
and
(入库单号 
LIKE
 
'
win%
'
)) 
group
 
by
 物料内码,采购订单内码
None.gif
None.gif
--
select * from #Aipetech_T003
None.gif
None.gif
--
计算入库数量
None.gif
update
 #Aipetech_T002 
set
 入库数量
=
A003.入库数量 
from
 #aipetech_t003 a003,#aipetech_t002 a002 
where
 a002.物料内码
=
a003.物料内码
None.gif
None.gif
--
计算未完成数量
None.gif
update
 #Aipetech_T002 
set
 未完成数量
=
数量
-
入库数量
None.gif
None.gif
insert
 
into
 #Aipetech_T002
None.gif            (物料名称,入库数量,未完成数量)
None.gif            
select
 
'
合计:
'
,
sum
(入库数量),
sum
(未完成数量) 
from
 #Aipetech_t002
None.gif
None.gif
None.gif
--
select 采购订单内码,分录号,物料内码,物料编码,物料名称,入库单号,收货日期,单位,数量,入库数量,未完成数量,交货日期,备注 from #Aipetech_t002 a002
None.gif--
union
None.gif--
select 采购订单内码,1,物料内码,null,null,入库单号,单据日期,null,null,辅助实收数量,null,null,null from aipetech_v_icstockbill avi where ((采购订单内码=@InterID) and(入库单号 LIKE 'win%'))
None.gif--
order by 分录号 
None.gif
None.gif
None.gif
--
以下用游标来进行主细表的记录增加到#Aipetech_T004表中
None.gif
Create
 
Table
 #Aipetech_T004
None.gif    (
None.gif    采购订单内码 
int
,
None.gif    分录号 
int
,
None.gif    物料内码 
int
,
None.gif    物料编码 
varchar
(
80
),
None.gif    物料名称 
varchar
(
80
),
None.gif    收货日期 
datetime
,
None.gif    入库单号 
varchar
(
80
),
None.gif    单位 
varchar
(
30
),
None.gif    数量 
decimal
(
13
),
None.gif    入库数量 
decimal
(
13
default
 
0
,
None.gif    未完成数量 
decimal
(
13
default
 
0
,
None.gif    交货日期 
datetime
,
None.gif    备注 
varchar
(
255
)
None.gif    )
None.gif
None.gif
declare
 
@T1
 
int
,
@T2
 
int
,
@T3
 
int
,
@T4
 
varchar
(
80
),
@T5
 
varchar
(
80
),
@T6
 
datetime
,
@T7
 
varchar
(
80
),
None.gif
@T8
 
varchar
(
30
),
@T9
 
decimal
(
13
),
@T10
 
decimal
(
13
),
@T11
 
decimal
(
13
),
@T12
 
datetime
,
@T13
 
varchar
(
255
)
None.gif
None.gif
declare
 A_T004_cur scroll 
cursor
 
for
 
select
 
*
 
from
 #Aipetech_T002
None.gif
open
 A_T004_cur
None.gif
Fetch
 first 
from
 A_T004_cur 
into
 
@T1
,
@T2
,
@T3
,
@T4
,
@T5
,
@T6
,
@T7
,
@T8
,
@T9
,
@T10
,
@T11
,
@T12
,
@T13
None.gif
None.gif
while
 
@@fetch_status
=
0
None.gif
begin
None.gif
insert
 
into
 #Aipetech_T004 
values
(
@T1
,
@T2
,
@T3
,
@T4
,
@T5
,
@T6
,
@T7
,
@T8
,
@T9
,
@T10
,
@T11
,
@T12
,
@T13
)
None.gif
insert
 
into
 #Aipetech_T004
None.gif
select
 采购订单内码,
@T2
,物料内码,物料代码,物料名称,单据日期,入库单号,
@T8
,
null
,辅助实收数量,
null
,
null
,
null
 
from
 aipetech_v_icstockbill avi 
where
 ((采购订单内码
=
@InterID
and
(入库单号 
LIKE
 
'
win%
'
)
and
 (物料内码
=
@T3
))
None.gif
Fetch
 
next
 
from
 A_T004_cur 
into
 
@T1
,
@T2
,
@T3
,
@T4
,
@T5
,
@T6
,
@T7
,
@T8
,
@T9
,
@T10
,
@T11
,
@T12
,
@T13
None.gif
end
None.gif
None.gif
close
 A_T004_cur
None.gif
deallocate
 A_T004_cur
None.gif
None.gif
None.gif
--
select * from #aipetech_t002
None.gif
None.gif
select
 
*
 
from
 #Aipetech_T004
None.gif
--
select 采购订单内码,1,物料内码,null,null,入库单号,单据日期,null,null,辅助实收数量,null,null,null from aipetech_v_icstockbill avi where ((采购订单内码=@InterID) and(入库单号 LIKE 'win%'))
None.gif
None.gif
None.gif
Drop
 
Table
 #Aipetech_T002
None.gif
Drop
 
Table
 #Aipetech_T003
None.gif
Drop
 
Table
 #Aipetech_T004
None.gif
GO

转载地址:http://mwdmx.baihongyu.com/

你可能感兴趣的文章
PostgreSQL数据库中的常见错误
查看>>
jquery 控制 video 视频播放和暂停
查看>>
XCode调试多线程遭遇海森伯效应一例
查看>>
ie6下浮动使绝对定位元素莫名消失的问题
查看>>
FBReaderJ 1.6.3 发布,Android 电子书阅读器
查看>>
Java编程常见问题汇总(四)
查看>>
Hadoop 学习系列(四)之 MapReduce 原理讲解
查看>>
函数throttle、debounce介绍
查看>>
源码阅读:SDWebImage(三)——NSData+ImageContentType
查看>>
十六、类的真正形态
查看>>
spring-cloud Sleuth
查看>>
Python 进阶之路 (十一) 再立Flag, 社区最全的itertools深度解析(下)
查看>>
微信分享,二次分享(移动web端)
查看>>
蚂蚁金服智能推荐引擎解决方案与实践
查看>>
PC比电脑好玩的秘密是什么?答案就是因为有这些神奇的网站!
查看>>
30秒的PHP代码片段(2)数学 - Math
查看>>
助力中文文字识别突破,美团公开首个真实场景招牌图像数据集
查看>>
IOS常用框架集合
查看>>
Laravel 深入核心系列教程
查看>>
webpack 性能提速
查看>>