From bf7d4e71962a2adbb5d47a6638a6dae4b1eac012 Mon Sep 17 00:00:00 2001 From: paoloar77 Date: Sat, 7 Dec 2024 19:01:37 +0100 Subject: [PATCH] aa --- app/Http/Controllers/ArticleController.php | 51 ++++++++++------------ 1 file changed, 24 insertions(+), 27 deletions(-) diff --git a/app/Http/Controllers/ArticleController.php b/app/Http/Controllers/ArticleController.php index 1ecb0e42..ed929ba5 100755 --- a/app/Http/Controllers/ArticleController.php +++ b/app/Http/Controllers/ArticleController.php @@ -14,37 +14,34 @@ 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 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) { + $articoliVenduti = Article::join(DB::raw('(SELECT IdArticolo, MAX(DataOra) AS data FROM T_WEB_Articoli GROUP BY IdArticolo) b'), function ($join) { + $join->on('T_WEB_Articoli.IdArticolo', '=', 'b.IdArticolo') + ->on('T_WEB_Articoli.DataOra', '=', 'b.data'); + }) + ->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 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) { + ->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, - 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') + ->leftJoin(DB::raw('(SELECT l.IdTipoFormato, l.Descrizione as DescrizioneFormato FROM T_WEB_TipiFormato l JOIN (SELECT IdTipoFormato, MAX(DataOra) as data1 from T_WEB_TipiFormato GROUP BY IdTipoFormato) m ON l.IdTipoFormato = m.IdTipoFormato AND l.DataOra = m.data1 ) n'), function ($join) { + $join->on('T_WEB_Articoli.IdTipoFormato', '=', 'n.IdTipoFormato'); + }) + ->where('T_WEB_Articoli.IdArticolo', $idarticolo) + /* + ->leftJoin(DB::raw('(SELECT o.Codice, o.QtaDisponibile FROM T_WEB_Disponibile o JOIN (SELECT Codice, MAX(DataOra) as data1 from T_WEB_Disponibile GROUP BY Codice) p ON o.Codice = p.Codice AND o.DataOra = p.data1 ) q'), function($join) { + $join->on('T_WEB_Articoli.IdArticolo', '=', 'q.Codice'); + }) + */ + + //->where('T_WEB_Articoli.DataOra','>',$settingora->value) + ->where(function ($query) { + $query->where('DescrizioneStatoProdotto', 'In commercio') + ->orWhere('DescrizioneStatoProdotto', 'In prevendita') + ->orWhere('DescrizioneStatoProdotto', 'Prossima uscita'); + }) + //->where('DescrizioneTipologia','Video Streaming') + ->orderBy('dataOra', 'desc') ->get(); if ($articoliVenduti->isEmpty()) {