DataObjects/Core_group.php
[Pman.Core] / DataObjects / Core_group.php
index eaaf4c0..bbe969a 100644 (file)
@@ -54,28 +54,38 @@ class Pman_Core_DataObjects_Core_group extends DB_DataObject
             }
         }
 
-        //DB_DataObject::debugLevel(1);
-        $core_group = DB_DataObject::factory('core_group');
-        $cgmDBObj = DB_DataObject::Factory('core_group_member');
-        $cpObj = DB_DataObject::Factory('core_person');
+
+        
+        $cp = DB_DataObject::Factory('core_person')->tableName();
         $cgm = DB_DataObject::Factory('core_group_member')->tableName();
-        $cpObj->active = 1; // set the where condition with active = 1
-      
-        $core_group->joinAdd($cgmDBObj, array('joinType' => 'LEFT', 'useWhereAsOn' => false));
-        $core_group->joinAdd($cpObj, array('joinType' => 'LEFT', 'useWhereAsOn' => true));
-        $core_group->find();
-        //DB_DataObject::debugLevel();
-        /*$this->selectAdd("
+        
+        $this->selectAdd("
            (
-            SELECT 
-                count(user_id) 
-            FROM 
-                {$cgm}
-            WHERE 
-                {$this->tableName()}.id = {$cgm}.group_id
-            ) 
-            AS group_member_count            
-        ");*/
+            SELECT COUNT(core_group_member.user_id) 
+                FROM 
+                    core_group_member
+                LEFT JOIN
+                    core_person
+                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);