SQL中的一个问题可以帮助我吗?我有一个名为products的主表,还有一个名为prices的主表(其中根据供应商的价格是一对多),即查询如下
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
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
耽误您时间,实在对不起
发布于 2018-04-04 06:58:59
我有答案,使用外部应用:
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
https://stackoverflow.com/questions/49639462
复制相似问题