From 907dedfecead277ddf633ab3714b44950c1c518b Mon Sep 17 00:00:00 2001 From: paoloar77 Date: Sat, 7 Dec 2024 18:52:08 +0100 Subject: [PATCH] aa --- app/Http/Controllers/ArticleController.php | 85 ++++++++++++---------- 1 file changed, 45 insertions(+), 40 deletions(-) diff --git a/app/Http/Controllers/ArticleController.php b/app/Http/Controllers/ArticleController.php index b7ef4f64..971aa975 100755 --- a/app/Http/Controllers/ArticleController.php +++ b/app/Http/Controllers/ArticleController.php @@ -14,46 +14,51 @@ class ArticleController extends Controller private function queryArticlesSales() { try { - $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(); + $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, + 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('T_WEB_Articoli.Titolo', 'asc') + ->get(); if ($articoliVenduti->isEmpty()) { return response()->json(['message' => 'Nessun articolo trovato.'], 404);