db2新手求助

swoky 2009-05-25 12:01:49
有两张表:
product表
productId productName
---------------------------------
1 aaaaaa
2 bbbbbb

productAttribute表
productId attrName attrValue
-----------------------------------------------------
1 size 100
1 color red
1 width 50
*
一个产品有多个属性,现在只要查这三个即可

现在有一个查询要求:
用一个sql(不要存储过程之类的)把这两张表的数据查出来,结果要求如下:
productId productName size color width
--------------------------------------------------------
1 aaaaaaa 100 red 50
2 bbbbb ..........................

另外一个最重要的要求是;productAttribute表中的属性是不定的,比如说color属性,该产品可能没有,所以在productAttribure表中不会存在该条记录, 但是查出来的结果还得有这一列,只是值为null,如下

productId productName size color width
1 aaaaaaa 100 null 50

我这边数据库DB2的,写sql的时候如果能跟数据库搭配最好,
...全文
145 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
yangxiao_jiang 2009-05-25
  • 打赏
  • 举报
回复
可以实现
select productId,productName ,(select attrValue from productAttribute where productAttribute.productId=productId and attrName='size') as size , (select attrValue from productAttribute where productAttribute.productId=productId and attrName='color') as color, (select attrValue from productAttribute where productAttribute.productId=productId and attrName='width') as width
from product

效率很差。
Herb2 2009-05-25
  • 打赏
  • 举报
回复
好像left join 要改成 left outer join
Herb2 2009-05-25
  • 打赏
  • 举报
回复
product表
productId productName
---------------------------------
1 aaaaaa
2 bbbbbb

productAttribute表
productId attrName attrValue
-----------------------------------------------------
1 size 100
1 color red
1 width 50
--------------------------------------------------------------------------------------
select a.productId,a.productName,b.attrvalue as size,c.attrvalue as color,d.attrvalue as width
from product a
left join (select * from prodeuctattribute where attrname = 'size' ) b on a.productid = b.productid
left join (select * from prodeuctattribute where attrname = 'color' ) c on a.productid = c.productid
left join (select * from prodeuctattribute where attrname = 'width' ) d on a.productid = d.productid
swoky 2009-05-25
  • 打赏
  • 举报
回复
如果不考虑效率方面的问题,可以实现吗
Mr_Bean 2009-05-25
  • 打赏
  • 举报
回复
一般把这种查询定义成为交叉表 而这些一般都不好用一句sql很好的完成 即使完成效率也比较差 要么用报表工具 要么用存储过程 期待有更好的解决方法
内容概要:本文围绕基于Basisformer模型的时间序列锂离子电池SOC(State of Charge,荷电状态)预测展开研究,利用PyTorch框架实现深度学习模型的构建与训练。通过将历史充放电数据作为输入,Basisformer能够有效捕捉电池状态的动态变化特征,提升SOC预测精度。文中详细介绍了模型结构设计、数据预处理流程、训练策略及实验结果分析,并与传统方法进行对比,验证了该方法在复杂工况下的优越性与鲁棒性。该研究不仅展示了Basisformer在时序建模中的潜力,也为电池管理系统提供了高精度的状态估计解决方案。; 适合人群:具备一定Python编程基础和深度学习理论知识,熟悉PyTorch框架,从事电池管理系统、新能源汽车或智能预测方向研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于电动汽车、储能系统等领域的电池SOC高精度实时估算;②为电池健康管理(BMS)提供可靠的状态输入;③推动深度学习在时间序列预测中的实际落地,提升现有预测模型的泛化能力与稳定性; 阅读建议:建议读者结合标题为【锂电池SOC估计】【PyTorch】基于Basisformer时间序列锂离子电池SOC预测研究(python代码实现)的资源,重点研读所提供的Python代码,深入理解数据处理方式与模型网络结构的设计思路,尝试调整超参数以观察对预测性能的影响,从而全面掌握Basisformer在时序建模中的优势、适用边界及工程化实现路径。

5,888

社区成员

发帖
与我相关
我的任务
社区描述
IBM DB2 是美国IBM公司开发的一套关系型数据库管理系统,它主要的运行环境为UNIX(包括IBM自家的AIX)、Linux、IBM i(旧称OS/400)、z/OS,以及Windows服务器版本
社区管理员
  • DB2
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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