$core_group = DB_DataObject::factory('core_group');
if($core_group->get('name', $q['_count_member_by_name'])){
- $roo->jdata($core_group->memberCount());
+ $roo->jok($core_group->memberCount());
}
}
+ var_dump($q);
+ if(!empty($q['_with_member_id'])){
+ $this->selectAdd("
+ COALESE(
+ (SELECT id from core_group_member
+ WHERE ...
+
+ LIMIT 1
+ ),0) as ....
+ ");
+ }
+
- $this->selectAdd("
+ $cp = DB_DataObject::Factory('core_person')->tableName();
+ $cgm = DB_DataObject::Factory('core_group_member')->tableName();
+
+ $this->selectAdd("
(
- SELECT
- count(user_id)
- FROM
- core_group_member
- WHERE
- core_group.id = core_group_member.group_id
- )
- AS group_member_count
+ SELECT COUNT(${cgm}.user_id)
+ FROM
+ {$cgm}
+ LEFT JOIN
+ {$cp}
+ ON
+ ${cp}.id = {$cgm}.user_id
+ WHERE
+ ${cgm}.group_id = {$this->tableName()}.id
+ AND
+ ${cp}.active = 1
+ ) AS group_member_count
");
+
+ /*WHERE
+ {$this->tableName()}.id = core_group_member.group_id
+ AND
+ core_group_member.user_id = core_person.id
+ AND
+ core_person.active = 1
+ )*/
+
+// $this->whereAdd("{$this->tableName()}.id = core_group_member.group_id");
+// $this->whereAdd("core_group_member.user_id = core_person.id");
+// $this->whereAdd("core_person.active = 1");
+
+
+ /*$cgmDBObj->joinAdd($cpObj);
+ $this->joinAdd($cgmDBObj);
+ DB_DataObject::debugLevel();*/
}
function toEventString() {
{
$gm = DB_Dataobject::factory('core_group_member');
$gm->group_id = $this->id;
+ $gm->autoJoin();
+ $gm->whereAdd('join_user_id_id.active = 1');
+ //PDO_DAtaObject::DebugLevel(1);
return $gm->count();
}
{
$gm = DB_Dataobject::factory('core_group_member');
$gm->group_id = $this->id;
+ $gm->autoJoin();
+ $gm->whereAdd('join_user_id_id.active = 1');
return $gm->fetchAll('user_id');
}
function initGroups()
{
-
+
$g = DB_DataObject::factory($this->tableName());
$g->type = 0;
$g->name = 'Administrators';