Из требования я понимаю, что в каждой категории должна быть 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;
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
}