diff --git a/app/Http/Controllers/ArticleController.php b/app/Http/Controllers/ArticleController.php index a43747d3..1ecb0e42 100755 --- a/app/Http/Controllers/ArticleController.php +++ b/app/Http/Controllers/ArticleController.php @@ -15,37 +15,37 @@ class ArticleController extends Controller { try { $articoliVenduti = Article::join('T_WEB_Ordini', 'T_WEB_Articoli.idArticolo', '=', 'T_WEB_Ordini.codArticoloGM') - ->leftJoin(DB::raw('(SELECT e.IdStatoProdotto, e.Descrizione as DescrizioneStatoProdotto - FROM T_WEB_StatiProdotto e - JOIN (SELECT IdStatoProdotto, MAX(DataOra) as data1 - FROM T_WEB_StatiProdotto - GROUP BY IdStatoProdotto) c - ON e.IdStatoProdotto = c.IdStatoProdotto AND e.DataOra = c.data1) f'), function ($join) { + ->leftJoin(DB::raw('(SELECT DISTINCT e.IdStatoProdotto, e.Descrizione as DescrizioneStatoProdotto + FROM T_WEB_StatiProdotto e + JOIN (SELECT IdStatoProdotto, MAX(DataOra) as data1 + FROM T_WEB_StatiProdotto + GROUP BY IdStatoProdotto) c + ON e.IdStatoProdotto = c.IdStatoProdotto AND e.DataOra = c.data1) f'), function ($join) { $join->on('T_WEB_Articoli.IdStatoProdotto', '=', 'f.IdStatoProdotto'); - }) - ->leftJoin(DB::raw('(SELECT g.IdTipologia, g.Descrizione as DescrizioneTipologia - FROM T_WEB_Tipologie g - JOIN (SELECT IdTipologia, MAX(DataOra) as data1 - FROM T_WEB_Tipologie - GROUP BY IdTipologia) h - ON g.IdTipologia = h.IdTipologia AND g.DataOra = h.data1) i'), function ($join) { + }) + ->leftJoin(DB::raw('(SELECT DISTINCT g.IdTipologia, g.Descrizione as DescrizioneTipologia + FROM T_WEB_Tipologie g + JOIN (SELECT IdTipologia, MAX(DataOra) as data1 + FROM T_WEB_Tipologie + GROUP BY IdTipologia) h + ON g.IdTipologia = h.IdTipologia AND g.DataOra = h.data1) i'), function ($join) { $join->on('T_WEB_Articoli.IdTipologia', '=', 'i.IdTipologia'); - }) - ->where('DescrizioneTipologia', 'Libri') - ->whereIn('f.DescrizioneStatoProdotto', ['In commercio']) - ->selectRaw(' - T_WEB_Articoli.idArticolo, - T_WEB_Articoli.Ean13, - T_WEB_Articoli.Titolo, - SUM(T_WEB_Ordini.Qta) as totaleVenduti, - SUM(CASE WHEN T_WEB_Ordini.DataOra >= DATEADD(month, -1, GETDATE()) THEN T_WEB_Ordini.qta ELSE 0 END) as totaleVendutiUltimoMese, - SUM(CASE WHEN T_WEB_Ordini.DataOra >= DATEADD(month, -6, GETDATE()) THEN T_WEB_Ordini.qta ELSE 0 END) as totaleVendutiUltimi6Mesi, - SUM(CASE WHEN T_WEB_Ordini.DataOra >= DATEADD(year, -1, GETDATE()) THEN T_WEB_Ordini.qta ELSE 0 END) as totaleVendutiUltimoAnno, - SUM(CASE WHEN T_WEB_Ordini.DataOra >= DATEADD(year, -2, GETDATE()) THEN T_WEB_Ordini.qta ELSE 0 END) as totaleVendutiUltimi2Anni, - MAX(T_WEB_Ordini.DataOra) AS ultimoOrdine - ') - ->groupBy('T_WEB_Articoli.idArticolo', 'T_WEB_Articoli.Titolo', 'T_WEB_Articoli.Ean13') - ->get(); + }) + ->where('DescrizioneTipologia', 'Libri') + ->whereIn('f.DescrizioneStatoProdotto', ['In commercio']) + ->selectRaw(' + T_WEB_Articoli.idArticolo, + T_WEB_Articoli.Ean13, + T_WEB_Articoli.Titolo, + SUM(T_WEB_Ordini.Qta) as totaleVenduti, + SUM(CASE WHEN T_WEB_Ordini.DataOra >= DATEADD(month, -1, GETDATE()) THEN T_WEB_Ordini.qta ELSE 0 END) as totaleVendutiUltimoMese, + SUM(CASE WHEN T_WEB_Ordini.DataOra >= DATEADD(month, -6, GETDATE()) THEN T_WEB_Ordini.qta ELSE 0 END) as totaleVendutiUltimi6Mesi, + SUM(CASE WHEN T_WEB_Ordini.DataOra >= DATEADD(year, -1, GETDATE()) THEN T_WEB_Ordini.qta ELSE 0 END) as totaleVendutiUltimoAnno, + SUM(CASE WHEN T_WEB_Ordini.DataOra >= DATEADD(year, -2, GETDATE()) THEN T_WEB_Ordini.qta ELSE 0 END) as totaleVendutiUltimi2Anni, + MAX(T_WEB_Ordini.DataOra) AS ultimoOrdine + ') + ->groupBy('T_WEB_Articoli.idArticolo', 'T_WEB_Articoli.Titolo', 'T_WEB_Articoli.Ean13') + ->get(); if ($articoliVenduti->isEmpty()) { return response()->json(['message' => 'Nessun articolo trovato.'], 404);