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. 一些特殊字符,如“&”,“- ...
随机推荐
- hMailserver设置外部反病毒扫描程序
刚在5dmail上发现有人提出一个问题,他在hmailserver的外部病毒扫描程序中使用了瑞星那个娱乐货,结果呢,说瑞星太勇猛了,所有附件都认为病毒了,这是怎么个情况呢? 先从hmailadmin里 ...
- BZOJ2229: [Zjoi2011]最小割
题解: 真是一道神题!!! 大家还是围观JZP的题解吧(网址找不到了...) 代码: #include<cstdio> #include<cstdlib> #include&l ...
- 物联网操作系统HelloX应用编程指南
HelloX操作系统应用编程指南 HelloX应用开发概述 可以通过三种方式,在HelloX操作系统基础上开发应用: 1. 以内部命令方式实现应用,直接编译链接到HelloX的内核she ...
- HWM的实验
HWM是数据段中使用空间和未使用空间之间的界限,假如现有自由链表上的数据块不能满足需求,Oracle把HWM指向的数据块加入到自由链表上,HWM向前移动到下一个数据块.简单说,一个数据段中,HWM左边 ...
- 在linux设置环境变量
1.直接用export命令:#export PATH=$PATH:/opt/au1200_rm/build_tools/bin查看是否已经设好,可用命令export查看: [root@localhos ...
- liunx下mysql数据库使用之三范式,关系模型设计注意项,安装目录结构
数据库的三范式第一范式===>每行记录的属性,是原子的,拆到不可拆为止.===>例如:一个人的籍贯,可以拆分为,省,市,县,乡,村 第二范式===>每行记录的非主属性(非主键属性), ...
- 【编程之美】计算1-N中含1的个数
转自:点我 1位数的情况: 在解法二中已经分析过,大于等于1的时候,有1个,小于1就没有. 2位数的情况: N=13,个位数出现的1的次数为2,分别为1和11,十位数出现1的次数为4,分别为10,1 ...
- java jvm学习笔记十二(访问控制器的栈校验机制)
欢迎装载请说明出处:http://blog.csdn.net/yfqnihao 本节源码:http://download.csdn.net/detail/yfqnihao/4863854 这一节,我们 ...
- 为redis分配一个新的端口
为redis分配一个8888端口,操作步骤如下:1.$REDIS_HOME/redis.conf重新复制一份,重命名为redis8888.conf.2.打开redis8888.conf配置文件,找到p ...
- HDU 4405-Aeroplane chess(概率dp)
题意: n+1格飞行棋,编号0-n,从0格开始,每次扔一个色子,得到的点数就向前走几步,但有有些格子到达后可以直接飞到后面的格子, 当到达>=n的地方结束,求结束扔色子的期望次数. 分析: dp ...