本文整理匯總了PHP中Statement::_count方法的典型用法代碼示例。如果您正苦於以下問題:PHP Statement::_count方法的具體用法?PHP Statement::_count怎麽用?PHP Statement::_count使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Statement
的用法示例。
在下文中一共展示了Statement::_count方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: get
/**
*
* @param Request $request
* @param stdClass $user
* @param array $limit
* @return \self
*/
public static function get(Request $request, stdClass $user, array $limit = array('offset' => 0, 'limit' => 10))
{
$where = array();
$where_str = '';
if ($request->has('show') && $request->get('show') == 'filter') {
if ($request->has('type')) {
$where[] = "s.type IN ('" . implode("', '", (array) $request->get('type')) . "')";
}
if ($request->has('categories')) {
$where[] = "category IN ('" . implode("', '", (array) $request->get('categories')) . "')";
}
if ($request->has('status')) {
$where[] = "status IN ('" . implode("', '", (array) $request->get('status')) . "')";
}
if ($request->has('time')) {
switch ($request->get('time')) {
case 'today':
$where[] = "date > " . mktime(0, 0, 0, date('n'), date('d'), date('Y'));
break;
case 'week':
$where[] = "date > " . time() - 7 * 24 * 3600;
break;
case 'month':
$where[] = "date > " . time() - 30 * 24 * 3600;
break;
default:
break;
}
}
if ($where) {
$where_str = "WHERE " . implode(' AND ', $where) . " ";
}
}
switch ($request->get('order')) {
default:
case 'vote':
$order = ' ORDER BY (plus_count - minus_count) DESC ';
break;
case 'date':
$order = ' ORDER BY `date` DESC ';
break;
case 'comments':
$order = ' ORDER BY `comm_num` DESC ';
break;
}
$count_query = "SELECT COUNT(*)AS count FROM " . PREFIX . "_statement AS s " . $where_str;
$count = self::$db->super_query($count_query);
self::$_count = $count['count'];
$query = "SELECT s.*, l.statement_id AS isset FROM " . PREFIX . "_statement AS s\n LEFT JOIN " . PREFIX . "_statement_log AS l\n ON l.statement_id=s.id AND ((l.user_id AND l.user_id={$user->user_id}) OR l.ip_address='" . $user->ip_address . "')\n {$where_str}{$order}LIMIT " . $limit['offset'] . ", " . $limit['limit'];
self::$db->query($query);
$sts = array();
while ($row = self::$db->get_row()) {
$sts[] = new self($row);
}
return $sts;
}