From 81149f570a8b29b155be83e72b2681bb63efa6fc Mon Sep 17 00:00:00 2001 From: paoloar77 Date: Sat, 7 Dec 2024 18:55:29 +0100 Subject: [PATCH] aa --- app/Http/Controllers/ArticleController.php | 71 +++++++++------------- 1 file changed, 29 insertions(+), 42 deletions(-) diff --git a/app/Http/Controllers/ArticleController.php b/app/Http/Controllers/ArticleController.php index 971aa975..a43747d3 100755 --- a/app/Http/Controllers/ArticleController.php +++ b/app/Http/Controllers/ArticleController.php @@ -15,50 +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) { - $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 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') + }) + ->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') - ->orderBy('T_WEB_Articoli.Titolo', 'asc') - ->get(); + ->get(); if ($articoliVenduti->isEmpty()) { return response()->json(['message' => 'Nessun articolo trovato.'], 404);