一句Sql能否解决这个问题

月光下的土豆 2013-10-31 01:58:46
组大家准备点数据

create table #tmp(
合同号 nvarchar(100),
产品ID nvarchar(100),
日期 datetime
)
INSERT INTO #tmp
SELECT 'XSHT000619','电脑','2013-10-31' UNION ALL
SELECT 'XSHT000619','主板','2013-10-31' UNION ALL
SELECT 'XSHT000619','机箱','2013-10-31' UNION ALL
SELECT 'XSHT000620','硬盘','2013-10-31' UNION ALL
SELECT 'XSHT000620','鼠标','2013-10-31' UNION ALL
SELECT 'XSHT000620','显示器','2013-10-31' UNION ALL
SELECT 'XSHT000618','桌子','2013-10-31' UNION ALL
SELECT 'XSHT000618','桌子','2013-09-30' UNION ALL
SELECT 'XSHT000620','硬盘','2013-09-30'


把以上数据整理成如下数据


整理原则,同一个合同的同一个产品,如果“日期”跨月就抓取出来
...全文
214 8 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
ywx41769 2013-11-03
  • 打赏
  • 举报
回复
select * from #tmp where 合同号+产品id in(select iie from ( select RANK() over(partition by 合同号+产品id order by substring(convert(varchar(10),日期,120),6,2)) as iid, 合同号+产品id iie from #tmp ) a where iid>1) order by 合同号+产品id,日期 asc
詩和遠方 2013-11-02
  • 打赏
  • 举报
回复
自连接即可:
select a.[合同号],a.[产品ID],a.[日期]
from #tmp a inner join #tmp b 
on a.[合同号] = b.[合同号] and a.[产品ID] = b.[产品ID]
where datepart(mm,a.[日期]) <> datepart(mm,b.[日期])
order by a.[合同号]

/*
合同号         产品ID        日期
---------------------------------------------------
XSHT000618     桌子          2013-09-30 00:00:00.000
XSHT000618     桌子          2013-10-31 00:00:00.000
XSHT000620     硬盘          2013-09-30 00:00:00.000
XSHT000620     硬盘          2013-10-31 00:00:00.000

(4 行受影响)
*/
LongRui888 2013-10-31
  • 打赏
  • 举报
回复
是这样吗:

create table #tmp(
	合同号 nvarchar(100),
	产品ID nvarchar(100),
	日期 datetime
)
INSERT INTO #tmp
SELECT 'XSHT000619','电脑','2013-10-31' UNION ALL
SELECT 'XSHT000619','主板','2013-10-31' UNION ALL
SELECT 'XSHT000619','机箱','2013-10-31' UNION ALL
SELECT 'XSHT000620','硬盘','2013-10-31' UNION ALL
SELECT 'XSHT000620','鼠标','2013-10-31' UNION ALL
SELECT 'XSHT000620','显示器','2013-10-31' UNION ALL
SELECT 'XSHT000618','桌子','2013-10-31' UNION ALL
SELECT 'XSHT000618','桌子','2013-09-30' UNION ALL
SELECT 'XSHT000620','硬盘','2013-09-30'


select 合同号,产品ID,日期
from
(
select *,
       count(*) over(partition by 合同号,产品ID) as rownum,
       min(日期) over(partition by 合同号,产品ID) as min_date,
       max(日期) over(partition by 合同号,产品ID) as max_date
from #tmp
)t
where rownum >= 2
      and datediff(month,min_date,max_date) >=1
/*
合同号	    产品ID	日期
XSHT000618	桌子	    2013-10-31 00:00:00.000
XSHT000618	桌子	    2013-09-30 00:00:00.000
XSHT000620	硬盘	    2013-09-30 00:00:00.000
XSHT000620	硬盘	    2013-10-31 00:00:00.000
*/
Andy__Huang 2013-10-31
  • 打赏
  • 举报
回复
select t1.*
from #tmp t1
where exists(select 1
from (
select a.合同号,a.产品ID,convert(varchar(7),日期,120) as 日期
from #tmp a
inner join 
	(select 合同号,产品ID,COUNT(*) as num
	from #tmp
	group by 合同号,产品ID
	having COUNT(*)>1
	)b on a.合同号=b.合同号 and a.产品ID=b.产品ID
group by a.合同号,a.产品ID,convert(varchar(7),日期,120)
having COUNT(*)=1
)t2 where t1.合同号=t2.合同号 and t1.产品ID=t2.产品ID)

/*
合同号	产品ID	日期
XSHT000620	硬盘	2013-10-31 00:00:00.000
XSHT000618	桌子	2013-10-31 00:00:00.000
XSHT000618	桌子	2013-09-30 00:00:00.000
XSHT000620	硬盘	2013-09-30 00:00:00.000
*/
lzw_0736 2013-10-31
  • 打赏
  • 举报
回复

--如果這樣跨年也行:
SELECT a.*
FROM #tmp a LEFT JOIN  #tmp b ON a.合同号=b.合同号 AND a.产品ID=b.产品ID
WHERE CONVERT(CHAR(7),a.[日期],20)<>CONVERT(CHAR(7),b.[日期],20)
ORDER BY 合同号,产品ID,日期
lzw_0736 2013-10-31
  • 打赏
  • 举报
回复

;WITH a1 AS
(
SELECT DISTINCT [合同号],[产品ID],CONVERT(CHAR(7),[日期],20) ym
FROM #tmp
)
,a2 AS
(
SELECT [合同号],[产品ID]
FROM a1
GROUP BY [合同号],[产品ID]
HAVING COUNT(*)>1
)
SELECT a.*
FROM #tmp a
INNER JOIN a2 b ON a.[合同号]=b.[合同号] AND a.[产品ID]=b.[产品ID]
發糞塗牆 2013-10-31
  • 打赏
  • 举报
回复

SELECT a.*
FROM #tmp a LEFT JOIN  #tmp b ON a.合同号=b.合同号 AND a.产品ID=b.产品ID
WHERE DATEPART(MONTH,a.日期)<>DATEPART(MONTH,b.日期)
ORDER BY 合同号,产品ID,日期

/*
合同号                                                                                                  产品ID                                                                                                 日期
---------------------------------------------------------------------------------------------------- ---------------------------------------------------------------------------------------------------- -----------------------
XSHT000618                                                                                           桌子                                                                                                   2013-09-30 00:00:00.000
XSHT000618                                                                                           桌子                                                                                                   2013-10-31 00:00:00.000
XSHT000620                                                                                           硬盘                                                                                                   2013-09-30 00:00:00.000
XSHT000620                                                                                           硬盘                                                                                                   2013-10-31 00:00:00.000
*/
發糞塗牆 2013-10-31
  • 打赏
  • 举报
回复
SELECT a.*--合同号,产品ID,日期 FROM #tmp a LEFT JOIN #tmp b ON a.合同号=b.合同号 AND a.产品ID=b.产品ID WHERE DATEPART(MONTH,a.日期)<>DATEPART(MONTH,b.日期)
Visual Studio Code 是由微软开发的一款免费、开源、跨平台的现代化轻量级代码编辑器,自发布以来迅速成为全球开发者最受欢迎的工具之一。它结合了编辑器的轻便性和集成开发环境(IDE)的强大功能,支持多种编程语言和开发场景,核心特点: 1. 跨平台支持 可在 Windows、macOS 和 Linux 上运行,保持一致的用户体验。 2. 轻量级与高性能 启动速度快,占用资源少,适合处理大型项目或低配置设备。 3. 智能代码补全 内置 IntelliSense(智能感知),提供代码提示、参数信息、快速修复等功能,支持 JavaScript、TypeScript、Python、C++ 等主流语言。 4. 内置终端 直接在编辑器内打开集成终端(支持 PowerShell、CMD、Bash 等),方便执行命令行操作。 5. 调试工具 内置调试器,支持断点、变量监视、调用堆栈查看等,无需离开编辑器即可调试代码。 6. Git 集成 直接通过侧边栏管理 Git 仓库,支持提交、分支切换、冲突解决等操作。 7. 丰富的扩展生态系统 通过 Extensions Marketplace 可安装数千款插件,扩展功能包括: 语言支持:如 Java、Go、Rust 等。 主题与图标:自定义界面风格。 工具集成:如 Docker、Kubernetes、数据库连接等。 效率工具:如 REST Client、Live Server 等。 8. 自定义与主题 支持修改键盘快捷键、界面主题、文件图标等,打造个性化开发环境。 9. 多光标编辑 按住 Alt(Windows/Linux)或 Option(macOS)点击可添加多个光标,同时编辑多处代码。 10. 远程开发支持 通过 Remote - SSH、Remote - Containers 等扩展,可直接连接远程服务器或开发容器,实现无缝协作。

34,837

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧