FOR XML PATH的用法
USE [ChangHongWMS612]
GO
/****** Object: StoredProcedure [dbo].[st_WMS_SelStockInBillList] Script Date: 09/30/2015 10:32:23 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
/*
Author:zhuss
Date: 2014-12-18
Remark:Get Product StockIn Bill Information
原存储过程名称:SelStockInBillList
Update:hz
UpdateTime:2014-12-27
Remark:添加分页
exec st_WMS_SelStockInBillList 'WX20150603002','2014-05-01','2016-06-04','','','test',20,1
exec st_WMS_SelStockInBillList '','2014-05-01','2016-06-04','','','test',1000,1
*/
ALTER proc [dbo].[st_WMS_SelStockInBillList]
(
@BillNO varchar(50) = '',
@StartDate varchar(19) = '',
@EndDate varchar(19) = '',
@MO varchar(50) ='',
@Status varchar(20) = '',
@ItemNO varchar(50) = '',
@ItemName varchar(100)='',
@BillType varchar(10)='',
@Pagecount int=20,
@Pageindex int=1
)
as
select ID = IDENTITY(int,1,1),i.BillNo, BillName = b.[Desc],p.StockName , i.Date, i.TotalQty
, Status = case when i.status = 'new' then '已保存' when i.status ='appr' then '已审核' else '' end,s.ItemNO
, ProductNoList = convert(varchar(8000),null),ProductList = convert(varchar(8000),null),ItemTypeList=convert(varchar(4000),null),
MoList = convert(varchar(8000),null),RemarkList = convert(varchar(8000),null),QtyList = convert(varchar(8000),null)
, ItemCount = (select count(*) from WMS_StockInItem where BillNo = i.BillNo),i.SupplyNO as SupplyNo,i.MaterialBill
into #t_StockInBill
from WMS_StockInBill i
join WMS_StockInItem s on s.billno=i.billno
join WMS_ProductStorage p on i.StockNo = p.StockNO
join WMS_BillCategory b on i.BillType = b.Name and b.Type = 'ProdIn'
join WMS_Product pt on pt.ItemNo=s.ItemNO
where (@BillNO = '' or i.BillNO like '%' + @BillNO + '%')
and ((@StartDate = '' and @EndDate = '') or i.Date between @StartDate and @EndDate)
and (@MO = '' or s.MO like '%' +@Mo + '%')
and (@Status = '' or i.Status = @Status)
and (s.ItemNo like '%'+@ItemNO+'%' or @ItemNO='')
and (@ItemName='' or pt.ItemDesc like '%'+@ItemName+'%')
and (@BillType='' or i.BillType like '%'+@BillType+'%')
order by i.Date desc, i.BillNO desc
--删除一个入库单号有多个产品的,只保留最大的那一条记录
delete from #t_StockInBill
where id not in(select max(id) from #t_StockInBill group by BillNo)
update t set ProductNoList=STUFF((
SELECT ','+ m.ItemNO FROM WMS_StockInItem m WHERE m.billno=t.billno FOR XML PATH('')
),1 ,1, '')
,ProductList=STUFF((
SELECT ','+ ItemDesc from(select billno, ItemDesc from WMS_StockInItem m join WMS_Product p on m.ItemNO=p.ItemNo) m WHERE m.billno=t.billno FOR XML PATH('')
),1 ,1, '')
,ItemTypeList=STUFF((
SELECT ','+ ItemType from(select billno, ItemType from WMS_StockInItem m join WMS_Product p on m.ItemNO=p.ItemNo) m WHERE m.billno=t.billno FOR XML PATH('')
),1 ,1, '')
,MoList=STUFF((
SELECT ','+ m.Mo FROM WMS_StockInItem m WHERE m.billno=t.billno FOR XML PATH('')
),1 ,1, '')
,RemarkList=STUFF((
SELECT ','+ m.Remark FROM WMS_StockInItem m WHERE m.billno=t.billno FOR XML PATH('')
),1 ,1, ''),
QtyList=STUFF((
SELECT ','+ convert(varchar(10),m.InQty) FROM WMS_StockInItem m WHERE m.billno=t.billno FOR XML PATH('')
),1 ,1, '')
from #t_StockInBill t
-- update t set ProductList = p.ItemDesc,ProductNoList=p.Itemno,MoList=i.Mo,RemarkList=i.Remark, QtyList = convert(varchar(100),i.InQty)
--from #t_StockInBill t
--join WMS_StockInItem i on t.BillNo = i.BillNo
--join WMS_Product p on p.ItemNo = i.ItemNo
--where t.ItemCount =1
-- declare @ProductList varchar(8000),@ProductNoList varchar(8000),@MoList varchar(8000), @RemarkList varchar(8000),
-- @QtyList varchar(8000), @vBillNo varchar(50)
-- declare CursorD cursor local
-- For select b.BillNo
-- from #t_StockInBill b
-- where ItemCount>1
--Open CursorD
--Fetch next From CursorD Into @vBillNo
--While(@@Fetch_Status = 0)
-- Begin
-- select @ProductList = '',@ProductNoList='',@MoList='',@RemarkList='', @QtyList= ''
-- select @ProductList = case when @ProductList = '' then p.ItemDesc else @ProductList+','+p.ItemDesc end,
-- @ProductNoList = case when @ProductNoList = '' then p.ItemNo else @ProductNoList+','+p.ItemNo end,
-- @MoList = case when @MoList = '' then i.Mo else @MoList+','+i.Mo end,
-- @RemarkList = case when @RemarkList = '' then i.Remark else @RemarkList+','+i.Remark end
-- , @QtyList = case when @QtyList = '' then convert(varchar(100),i.InQty) else @QtyList + ','+convert(varchar(100),i.InQty) end
-- from WMS_StockInItem i
-- join WMS_Product p on p.ItemNo = i.ItemNo
-- where i.BillNo = @vBillNo
-- update #t_StockInBill set ProductList = @ProductList,ProductNoList = @ProductNoList,
-- RemarkList=@RemarkList,QtyList = @QtyList where BillNo = @vBillNo
-- Fetch next From CursorD Into @vBillNo
--End
--Close CursorD
--Deallocate CursorD
select ID = IDENTITY(int,1,1),BillNo, BillName,MoList, StockName, Date, TotalQty
, Status, ProductNoList,ProductList,ItemTypeList,QtyList, ItemCount,SupplyNo,RemarkList,MaterialBill
into #t_StockInBill2
from #t_StockInBill
declare @row_from int, @row_to int,@out_total_rows int
select @out_total_rows = count(*) from #t_StockInBill2
execute st_MES_RS_Pages @out_total_rows, @Pagecount, @Pageindex, @row_from output, @row_to output
select * from #t_StockInBill2
where ID between @row_from and @row_to
order by ID
select @out_total_rows
FOR XML PATH的用法的更多相关文章
- SQLServer中sql for xml path 的用法
我们通常需要获取一个多行的某个字段拼出的字符串,我们可以使用for xml path进行处理:下面将介绍for xml path的具体用法: 创建测试表&插入测试数据 在数据库中新增测试表 C ...
- Sql server—— for xml path简单用法(可以按照分组把相同组的列中的不同的值,像字符串一样拼接在一起显示在分组之后的列中。)
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAI8AAACWCAIAAABo2EyXAAAKeklEQVR4nO2dy27rNh7G+U7CFIrfZX
- FOR XML PATH 函数用法
一.FOR XML PATH 简单介绍 那么还是首先来介绍一下FOR XML PATH ,假设现在有一张兴趣爱好表(hobby)用来存放兴趣爱好,表结构如下: 接下来我们来看 ...
- SQL SERVER数据库内 FOR XML PATH 函数用法
把自己点点滴滴的学习记录下来!!!! 一.FOR XML PATH 简单介绍 那么还是首先来介绍一下FOR XML PATH ,假设现在有一张兴趣爱好表(TBJTXXCE)用来存放就诊患者信息,表结构 ...
- for xml path以及sql合并查询
sql中for xml path的用法. http://www.cnblogs.com/yanghaibo/archive/2010/06/04/1751405.html
- 使用 SQL的 for xml path来进行字符串拼接
本篇主要讲怎么利用SQL的FOR XML PATH 参数来进行字符串拼接,FOR XML PATH的用法很简单,它会以xml文件的形式来返回数据. 我的讲解步骤: 1:构造初始数据 2:提出问题 3: ...
- SQL FOR XML PATH 用法
FOR XML PATH 有的人可能知道有的人可能不知道,其实它就是将查询结果集以XML形式展现,有了它我们可以简化我们的查询语句实现一些以前可能需要借助函数活存储过程来完成的工作.那么以一个实例为主 ...
- SQL FOR XML PATH 和 Stuff 用法
sql stuff 用法 1.作用 删除指定长度的字符,并在指定的起点处插入另一组字符. 2.语法 STUFF ( character_expression , start , length ,cha ...
- 一个由正则表达式引发的血案 vs2017使用rdlc实现批量打印 vs2017使用rdlc [asp.net core 源码分析] 01 - Session SignalR sql for xml path用法 MemCahe C# 操作Excel图形——绘制、读取、隐藏、删除图形 IOC,DIP,DI,IoC容器
1. 血案由来 近期我在为Lazada卖家中心做一个自助注册的项目,其中的shop name校验规则较为复杂,要求:1. 英文字母大小写2. 数字3. 越南文4. 一些特殊字符,如“&”,“- ...
随机推荐
- 【C#学习笔记】读SQL Server2008
using System; using System.Data.SqlClient; namespace ConsoleApplication { class Program { static voi ...
- ffmpeg Windows下采集摄像头一帧数据,并保存为bmp图片
这里请注意,在编译ffmpeg时,不要使用--disable-devices选项. 使用 --enable-encoder=rawvideo --enable-decoder=rawvideo 启用r ...
- 配置ORACLE 客户端连接到数据库
--================================= -- 配置ORACLE 客户端连接到数据库 --================================= Oracle ...
- 深入浅出 iOS 之生命周期
转:http://blog.csdn.net/kesalin/article/details/6691766 iOS应用程序的生命周期相比 Android 应用程序的生命周期来说,没那么简明易懂,但是 ...
- 微信多媒体上传图片,创建卡券上传 LOGO
//*****************************************多媒体上传图片 begin******************************************** ...
- Handling HTTP 404 Error in ASP.NET Web API
Introduction: Building modern HTTP/RESTful/RPC services has become very easy with the new AS ...
- duilib combo控件,当鼠标滚动时下拉列表自动关闭的bug的修复
转载请说明出处,谢谢~~ 群里有朋友提到了使用Combo控件时,当下拉列表出现,此时鼠标滚轮滚动,下拉列表就自动消失了.我看了一下源码,这个bug的修复很简单. CComboUI控件被单击时创建CCo ...
- 【转载】【内存对齐(二)】__declspec( align(#) )的用法和大小计算
转自:http://www.cppblog.com/deercoder/archive/2011/03/13/141747.html 感谢作者! 在上面讲到了关于pack的内存对齐和计算方法,这里继续 ...
- asp.net(class0625)
1 SiteMapPath 面包屑导航控件 要想使用这个控件,必须创建一个站点地图,也就是 web.sitemap web.sitemap是一个xml文件: 根节点必须是:<siteMap> ...
- QT多线程笔记
1.QT多线程涉及到主线程和子线程之间交互大量数据的时候,使用QThread并不方便,因为run()函数本身不能接受任何参数,因此只能通过信号和槽的交互来获取数据,如果只是单方面简单交互数据还过得去, ...