我不是 php 的专业人士,但这太离谱了......我已经为这件事苦苦挣扎了好几天,我真的认为它必须很简单......
我在 Joomla 中的一个组件的功能中有这个:
function gTickets()
{
$user =& JFactory::getUser();
$user_id = (int) $user->get('id');
$db = JFactory::getDBO();
$db->setQuery($db->getQuery(true)
->select('*')
->from("#__usergroups"));
$groupss=$db->loadRowList();
$userGroups = $user->groups;
$return=array();
foreach ($groupss as $key=>$g){
if (array_key_exists($g[0],$userGroups))
array_push($return,$g[0]); }
$groupss=$return[0];
$db1 = JFactory::getDBO();
$db1->setQuery($db1->getQuery(true)
->select('*')
->from("#__user_usergroup_map")
->where("group_id = '$groupss'")
);
$groupss1=$db1->loadRowList();
$return1=array();
foreach ($groupss1 as $keya)
{
$user_id = $keya[0]; // the id of users
$where = "";
if ($this->is_staff)
$where .= " AND t.`staff_id`='".$user_id."'";
else
$where .= " AND t.`customer_id`='".$user_id."'";
$tickets = $this->_getList(
"SELECT t.id, t.subject, t.last_reply_customer, s.name AS status_name FROM
#__rsticketspro_tickets t LEFT JOIN #__rsticketspro_statuses s ON
(t.status_id=s.id) WHERE 1 $where ORDER BY `last_reply` DESC", 0,
$this->params->get('tickets_limit', 3));
print_r($tickets);
return $tickets;
}
我认为它会将所有结果元素放入 $tickets 数组中......但它没有......当我打印数组时,我得到多个数组,而我只想要一个数组:
Array (
[0] => stdClass Object (
[id] => 1
[subject] => use1
[last_reply_customer] => 1
[status_name] => open
)
)
Array (
[0] => stdClass Object (
[id] => 3
[subject] => use2
[last_reply_customer] => 1
[status_name] => open
)
[1] => stdClass Object (
[id] => 2
[subject] => use2
[last_reply_customer] => 1
[status_name] => open
)
)
我尝试创建一个存储这些值的全局数组,但什么都没有......同样的事情发生......我认为这应该不难,但我不知道如何再寻找解决方案......
我希望数组看起来像这样:
Array (
[0] => stdClass Object (
[id] => 1
[subject] => use1
[last_reply_customer] => 1
[status_name] => open
)
[1] => stdClass Object (
[id] => 3
[subject] => use2
[last_reply_customer] => 1
[status_name] => open
)
[2] => stdClass Object (
[id] => 2
[subject] => use2
[last_reply_customer] => 1
[status_name] => open
)
)
谢谢!