首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >带有主详细信息的SQL语句,仅获取3个详细信息

带有主详细信息的SQL语句,仅获取3个详细信息
EN

Stack Overflow用户
提问于 2018-04-04 05:34:50
回答 1查看 22关注 0票数 0

SQL中的一个问题可以帮助我吗?我有一个名为products的主表,还有一个名为prices的主表(其中根据供应商的价格是一对多),即查询如下

代码语言:javascript
运行
复制
SELECT 
    p.id_empresa, p.codigo, p.descripcion, p.piezas_comprar,
    IIF(o.Costo IS NULL, 0, o.Costo) AS Costo, 
    IIF(r.Nombre IS NULL, 'S/P', r.Nombre) AS Proveedor, 
    IIF(r.Calificacion IS NULL, 0, r.Calificacion) AS Calificacion 
FROM 
    vw_productos_compras p 
LEFT JOIN
    access_pyme.dbo.Productos_Proveedores o ON p.Codigo = o.Codigo 
                                            AND p.id_empresa = o.id_empresa 
LEFT JOIN 
    access_pyme.dbo.Proveedores r ON o.id_proveedor = r.id_poveedor

我只需要每个供应商三条记录,也就是说,从供应商表中只需要三条记录,这三条记录是按其产品表的成本、别名或

%3产品记录% 1,%3产品记录% 2,%3产品记录%3

代码语言:javascript
运行
复制
00001 Supplier X $10
00001 Supplier Y $11
00001 Supplier Z $12
00002 Supplier X $8 
00002 Supplier Y $7 
00002 Supplier Z $9
00003 Supplier X $16
00003 Supplier Y $15
00003 Supplier Z $14

耽误您时间,实在对不起

EN

回答 1

Stack Overflow用户

发布于 2018-04-04 06:58:59

我有答案,使用外部应用:

代码语言:javascript
运行
复制
SELECT p.id_empresa, p.codigo, p.descripcion, p.piezas_comprar,
iif(o.Costo IS NULL, 0, o.Costo) AS Costo, iif(r.Nombre IS NULL,
'S/P', r.Nombre) AS Proveedor, iif(r.Calificacion IS NULL, 0,
r.Calificacion) AS Calificacion 
FROM            vw_productos_compras p

/*LEFT JOIN access_pyme.dbo.Productos_Proveedores o ON p.Codigo =
o.Codigo AND p.id_empresa = o.id_empresa */ 

OUTER APPLY  (   
  SELECT
 top 3 id_proveedor, Costo   
 FROM access_pyme.dbo.Productos_Proveedores o   
 WHERE p.Codigo = o.Codigo AND p.id_empresa = o.id_empresa ) o 

LEFT JOIN access_pyme.dbo.Proveedores r ON o.id_proveedor = r.id_poveedor
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49639462

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档