SQL 查询问题,立即解决立即给分

caryChen2012 2012-04-18 05:18:29

第一种写法就快很多,但我不想分开来写,第二种就超级慢,都是同样的写法,为什么区别这么大,
高手们,怎么样优化下面的写法,谢谢!
1,IF object_id('tempdb..#tmp1') is not null
drop table #tmp1
select INVENTBATCHID, ITEMID, PRODDATE, KTL_GOLDCOST, KTL_STONECOST,KTL_ACCCOST, KTL_LABOURCOST,
DESCRIPTION, PRODORDERQTY, KTL_PRODID,RECID,
(select top 1 ITEMID+
(case THK_INVENTD2ID when '' then THK_INVENTD2ID else '-'+THK_INVENTD2ID end)
+(case THK_INVENTD3ID when '' then THK_INVENTD3ID else '-'+THK_INVENTD3ID end)
+(case THK_INVENTD4ID when '' then THK_INVENTD4ID else '-'+THK_INVENTD4ID end)
+(case THK_INVENTDGOLDTYPEID when '' then THK_INVENTDGOLDTYPEID else '-'+THK_INVENTDGOLDTYPEID end)
from BOMVERSION
where BOMID = THK_RefBOMId and ITEMID <>'') as PRODUCTID
into #tmp1 from inventbatch as y
where left(inventbatchid,1) = 'P'

SELECT * FROM #tmp1 y
where not exists(select 1 from #tmp1
where y.INVENTBATCHID=INVENTBATCHID and RECID>y.RECID)


2,select INVENTBATCHID, ITEMID, PRODDATE, KTL_GOLDCOST, KTL_STONECOST,KTL_ACCCOST, KTL_LABOURCOST,
DESCRIPTION, PRODORDERQTY, KTL_PRODID,
(select top 1 ITEMID+
(case THK_INVENTD2ID when '' then THK_INVENTD2ID else '-'+THK_INVENTD2ID end)
+(case THK_INVENTD3ID when '' then THK_INVENTD3ID else '-'+THK_INVENTD3ID end)
+(case THK_INVENTD4ID when '' then THK_INVENTD4ID else '-'+THK_INVENTD4ID end)
+(case THK_INVENTDGOLDTYPEID when '' then THK_INVENTDGOLDTYPEID else '-'+THK_INVENTDGOLDTYPEID end)
from BOMVERSION
where BOMID = THK_RefBOMId and ITEMID <>'') as PRODUCTID into #tmp8 from INVENTBATCH as y
where not exists(select 1 from INVENTBATCH
where y.INVENTBATCHID=INVENTBATCHID and RECID>y.RECID)


...全文
93 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
lg314 2012-04-18
  • 打赏
  • 举报
回复
;with t1 as (
select INVENTBATCHID, ITEMID, PRODDATE, KTL_GOLDCOST, KTL_STONECOST,KTL_ACCCOST, KTL_LABOURCOST,
DESCRIPTION, PRODORDERQTY, KTL_PRODID,RECID,
(select top 1 ITEMID+
(case THK_INVENTD2ID when '' then THK_INVENTD2ID else '-'+THK_INVENTD2ID end)
+(case THK_INVENTD3ID when '' then THK_INVENTD3ID else '-'+THK_INVENTD3ID end)
+(case THK_INVENTD4ID when '' then THK_INVENTD4ID else '-'+THK_INVENTD4ID end)
+(case THK_INVENTDGOLDTYPEID when '' then THK_INVENTDGOLDTYPEID else '-'+THK_INVENTDGOLDTYPEID end)
from BOMVERSION
where BOMID = THK_RefBOMId and ITEMID <>'') as PRODUCTID
from inventbatch as y
where left(inventbatchid,1) = 'P')
SELECT * FROM t1 y
where not exists(select 1 from t1
where y.INVENTBATCHID=INVENTBATCHID and RECID>y.RECID)
option(hash join)

这样呢?
快溜 2012-04-18
  • 打赏
  • 举报
回复
where left(inventbatchid,1) = 'P'的条件第二种不要的吗,第一种采用临时表的方式确实可以提高查询效率
caryChen2012 2012-04-18
  • 打赏
  • 举报
回复
你这一个我试跑了一下,跟我的第2种写法一样慢
lg314 2012-04-18
  • 打赏
  • 举报
回复
;with t1 as (
select INVENTBATCHID, ITEMID, PRODDATE, KTL_GOLDCOST, KTL_STONECOST,KTL_ACCCOST, KTL_LABOURCOST,
DESCRIPTION, PRODORDERQTY, KTL_PRODID,RECID,
(select top 1 ITEMID+
(case THK_INVENTD2ID when '' then THK_INVENTD2ID else '-'+THK_INVENTD2ID end)
+(case THK_INVENTD3ID when '' then THK_INVENTD3ID else '-'+THK_INVENTD3ID end)
+(case THK_INVENTD4ID when '' then THK_INVENTD4ID else '-'+THK_INVENTD4ID end)
+(case THK_INVENTDGOLDTYPEID when '' then THK_INVENTDGOLDTYPEID else '-'+THK_INVENTDGOLDTYPEID end)
from BOMVERSION
where BOMID = THK_RefBOMId and ITEMID <>'') as PRODUCTID
from inventbatch as y
where left(inventbatchid,1) = 'P')
SELECT * FROM t1 y
where not exists(select 1 from t1
where y.INVENTBATCHID=INVENTBATCHID and RECID>y.RECID)


sql server 2000的话分开写吧。第一种是筛选出来的结果匹配筛选出来结果,第二种是筛选出来结果匹配未筛选结果,所以慢。更新下统计信息看看吧,还有检查下索引.
内容概要:本文围绕基于Basisformer模型的时间序列锂离子电池SOC(State of Charge,荷电状态)预测展开研究,利用PyTorch框架实现深度学习模型的构建与训练。通过将历史充放电数据作为输入,Basisformer能够有效捕捉电池状态的动态变化特征,提升SOC预测精度。文中详细介绍了模型结构设计、数据预处理流程、训练策略及实验结果析,并与传统方法进行对比,验证了该方法在复杂工况下的优越性与鲁棒性。该研究不仅展示了Basisformer在时序建模中的潜力,也为电池管理系统提供了高精度的状态估计解决方案。; 适合人群:具备一定Python编程基础和深度学习理论知识,熟悉PyTorch框架,从事电池管理系统、新能源汽车或智能预测方向研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于电动汽车、储能系统等领域的电池SOC高精度实时估算;②为电池健康管理(BMS)提供可靠的状态输入;③推动深度学习在时间序列预测中的实际落地,提升现有预测模型的泛化能力与稳定性; 阅读建议:建议读者结合标题为【锂电池SOC估计】【PyTorch】基于Basisformer时间序列锂离子电池SOC预测研究(python代码实现)的资源,重点研读所提供的Python代码,深入理解数据处理方式与模型网络结构的设计思路,尝试调整超参数以观察对预测性能的影响,从而全面掌握Basisformer在时序建模中的优势、适用边界及工程化实现路径。

684

社区成员

发帖
与我相关
我的任务
社区描述
智能路由器通常具有独立的操作系统,包括OpenWRT、eCos、VxWorks等,可以由用户自行安装各种应用,实现网络和设备的智能化管理。
linuxpython 技术论坛(原bbs)
社区管理员
  • 智能路由器社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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