diff --git a/app/Http/Controllers/ArticleController.php b/app/Http/Controllers/ArticleController.php index 47aaf3a9..b7ef4f64 100755 --- a/app/Http/Controllers/ArticleController.php +++ b/app/Http/Controllers/ArticleController.php @@ -14,52 +14,46 @@ class ArticleController extends Controller private function queryArticlesSales() { 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) { - $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) { - $join->on('T_WEB_Articoli.IdTipologia', '=', 'i.IdTipologia'); - }) - ->where('DescrizioneTipologia', 'Libri') - ->whereIn('f.DescrizioneStatoProdotto', ['In commercio']) - ->selectRaw(' - T_WEB_Articoli.idArticolo, - SUM(T_WEB_Ordini.Qta) as totaleVenduti, - T_WEB_Articoli.Ean13, - T_WEB_Articoli.Titolo') - - /* ->selectRaw(' - T_WEB_Articoli.idArticolo, - T_WEB_Articoli.Titolo, - T_WEB_Articoli.DataPubblicazione as DataPubblicazione, - T_WEB_Articoli.misure as misure, - T_WEB_Articoli.Ean13, - T_WEB_Articoli.Pagine as Pagine, - 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 - ') - */ - /*RANK() OVER (ORDER BY SUM(CASE WHEN T_WEB_Ordini.DataOra >= DATEADD(month, -3, GETDATE()) THEN T_WEB_Ordini.qta ELSE 0 END) DESC) as rank3M, - RANK() OVER (ORDER BY SUM(CASE WHEN T_WEB_Ordini.DataOra >= DATEADD(month, -6, GETDATE()) THEN T_WEB_Ordini.qta ELSE 0 END) DESC) as rank6M, - RANK() OVER (ORDER BY SUM(CASE WHEN T_WEB_Ordini.DataOra >= DATEADD(year, -1, GETDATE()) THEN T_WEB_Ordini.qta ELSE 0 END) DESC) as rank1Y - */ - // ->groupBy('T_WEB_Articoli.idArticolo', 'T_WEB_Articoli.Titolo', 'T_WEB_Articoli.Ean13', 'T_WEB_Articoli.DataPubblicazione', 'Pagine', 'misure') - ->groupBy('T_WEB_Articoli.idArticolo', 'T_WEB_Articoli.Titolo', 'T_WEB_Articoli.Ean13') - ->orderBy('totaleVenduti', 'desc') - ->get(); + $articoliVenduti = Article::select( + 'T_WEB_Articoli.idArticolo', + 'T_WEB_Articoli.Titolo', + 'T_WEB_Articoli.Ean13' + ) + ->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) { + $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) { + $join->on('T_WEB_Articoli.IdTipologia', '=', 'i.IdTipologia'); + }) + ->leftJoinSub( + function ($query) { + $query->from('T_WEB_Ordini') + ->select('codArticoloGM', DB::raw('SUM(Qta) as totaleVenduti')) + ->groupBy('codArticoloGM'); + }, + 'vendite', + function ($join) { + $join->on('T_WEB_Articoli.idArticolo', '=', 'vendite.codArticoloGM'); + } + ) + ->where('DescrizioneTipologia', 'Libri') + ->whereIn('f.DescrizioneStatoProdotto', ['In commercio']) + ->select( + 'T_WEB_Articoli.idArticolo', + 'T_WEB_Articoli.Titolo', + 'T_WEB_Articoli.Ean13', + 'vendite.totaleVenduti' + ) + ->orderBy('vendite.totaleVenduti', 'desc') + ->get(); if ($articoliVenduti->isEmpty()) { return response()->json(['message' => 'Nessun articolo trovato.'], 404);