72 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace App\Console\Commands;
 | 
						|
 | 
						|
use Illuminate\Console\Command;
 | 
						|
use Illuminate\Support\Facades\DB;
 | 
						|
 | 
						|
class AgregarEsBonoAPedidosAprobados extends Command
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * The name and signature of the console command.
 | 
						|
     *
 | 
						|
     * @var string
 | 
						|
     */
 | 
						|
    protected $signature = 'command:AgregarEsBonoAPedidosAprobados';
 | 
						|
 | 
						|
    /**
 | 
						|
     * The console command description.
 | 
						|
     *
 | 
						|
     * @var string
 | 
						|
     */
 | 
						|
    protected $description = 'Agrega "producto_bono" a la view PedidosAprobados';
 | 
						|
 | 
						|
    /**
 | 
						|
     * Create a new command instance.
 | 
						|
     *
 | 
						|
     * @return void
 | 
						|
     */
 | 
						|
    public function __construct()
 | 
						|
    {
 | 
						|
        parent::__construct();
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Execute the console command.
 | 
						|
     *
 | 
						|
     * @return int
 | 
						|
     */
 | 
						|
    public function handle(): int
 | 
						|
    {
 | 
						|
        DB::statement("
 | 
						|
            ALTER VIEW pedidos_aprobados(
 | 
						|
                grupo_de_compra_id,
 | 
						|
                grupo_de_compra_nombre,
 | 
						|
                grupo_de_compra_region,
 | 
						|
                producto_id,
 | 
						|
                producto_nombre,
 | 
						|
                producto_precio,
 | 
						|
                cantidad_pedida,
 | 
						|
                total_por_producto,
 | 
						|
                producto_es_bono
 | 
						|
            ) AS
 | 
						|
            SELECT
 | 
						|
              g.id as grupo_de_compra_id,
 | 
						|
              g.nombre as grupo_de_compra_nombre,
 | 
						|
              g.region as grupo_de_compra_region,
 | 
						|
              pr.id AS producto_id,
 | 
						|
              pr.nombre as producto_nombre,
 | 
						|
              pr.precio as producto_precio,
 | 
						|
              SUM(ps.cantidad) as cantidad_pedida,
 | 
						|
              pr.precio*SUM(ps.cantidad) as total_por_producto,
 | 
						|
              pr.bono
 | 
						|
            FROM grupos_de_compra g
 | 
						|
              JOIN subpedidos s ON (s.grupo_de_compra_id = g.id AND s.aprobado=1)
 | 
						|
              JOIN producto_subpedido ps ON (ps.subpedido_id = s.id)
 | 
						|
              JOIN productos pr ON (pr.id = ps.producto_id)
 | 
						|
            GROUP BY
 | 
						|
              g.id, g.nombre, pr.id, pr.nombre
 | 
						|
        ;");
 | 
						|
        return 0;
 | 
						|
    }
 | 
						|
}
 |