выполните итерации по свойствам php класса

Из требования я понимаю, что в каждой категории должна быть 1 строка, должно быть указано количество продавцов и указано имя продавца с самой последней датой.

Я подготовил нижеприведенный запрос, который генерирует некоторые примеры данных и предоставляет результат, как я понимаю.

Способ, которым это работает, заключается в том, что объем продавца рассчитывается путем присоединения таблицы категории продавца к таблице категории и последующего подсчета идентификатора продавца для каждой категории. Название более хитрое и требует использования внешнего применения, которое для каждой категории (для каждой строки) определяет первое имя в таблице торговца, упорядоченное по max (date) desc

. Надеюсь, это поможет, любые вопросы, пожалуйста, дайте мне знаю.

declare @Merchant table (
    MerchantId int,
    Name nvarchar(25),
    Date Date
);

declare @MerchantCategory table (
    MerchantId int,
    CategoryId int
);

declare @Category table (
    CategoryId int,
    Name nvarchar(25)
);

insert into @Merchant (MerchantId, Name, Date)
values
(1, 'Lucy', '2019-01-05'),
(2, 'Dave', '2019-01-30'),
(3, 'Daniel' ,'2019-02-01');

insert into @MerchantCategory (MerchantId, CategoryId)
values
(1, 4),
(1, 5),
(2, 4),
(3, 5);

insert into @Category (CategoryId, Name)
values
(4, 'Cat1'), 
(5, 'Cat2');

select c. Name, max(m.name) as MaxMerchantName, count(distinct mc2.merchantid) as Merchantvol from @Category c
left join @MerchantCategory mc2 on c.CategoryId=mc2.CategoryId
outer apply (select top 1 name, max(date) as date from @Merchant m inner join @MerchantCategory mc on m.MerchantId=mc.MerchantId where c.CategoryId=mc.CategoryId group by Name order by max(date) desc) m
group by c.Name;
18
задан Cameron A. Ellis 14 May 2009 в 02:11
поделиться

1 ответ

tl; dr;

// iterate public vars of class instance $class
foreach (get_object_vars($class) as $prop) {
   echo "$prop\n";
}

Объяснение:

http://nz.php.net/get_object_vars

class foo {
    private $a;
    public $b = 1;
    public $c;
    private $d;
    static $e;

    public function test() {
        var_dump(get_object_vars($this));
    }
}

$test = new foo;

var_dump(get_object_vars($test));

$test->test();

?>

array(2) {
  ["b"]=> int(1)
  ["c"]=> NULL
}

array(4) {
  ["a"]=> NULL
  ["b"]=> int(1)
  ["c"]=> NULL
  ["d"]=> NULL
}
28
ответ дан 30 November 2019 в 08:16
поделиться
Другие вопросы по тегам:

Похожие вопросы: