首页 > 编程 > PHP > 正文

php取出数组中指定长度的数据

2020-03-22 17:49:37
字体:
来源:转载
供稿:网友
  • 今天学了一个关于减少查询的思路。

    用实例来说明:

    题 外话,因为现在公司是做教育这块的那么就有热门课程、最新课程、感兴趣的课程、各科的课程、各个版本的课程

    如何能减注数据的查询

    我的方法是将满足基本条件的数据全部查询出来,


    $list_json = $this->accessCourse('ID DESC', 1);//查询出所以满足基本条件的数据,状态正常...$list = json_decode($list_json, true);//因为查询出来的是json格式这里将其转换成array格式		//热门课程		$toplist = array_sort($list, 'NUM', SORT_DESC);//二维数组排序		$this->assign('toplist', $toplist);		//感兴趣		$interest = findArrayList($list,9);//筛选出9条数据		$this->assign('interest', $interest);		//试听课程		$listen_yw = findArrayList($list,4,'SUBJECT',1);//语文		$listen_sx = findArrayList($list,4,'SUBJECT',2);//数学		$listen_yy = findArrayList($list,4,'SUBJECT',3);//英语		$listen_wl = findArrayList($list,4,'SUBJECT',4);//物理		$listen_hx = findArrayList($list,4,'SUBJECT',5);//化学		$this->assign('listen_yw', $listen_yw);		$this->assign('listen_sx', $listen_sx);		$this->assign('listen_yy', $listen_yy);		$this->assign('listen_wl', $listen_wl);		$this->assign('listen_hx', $listen_hx);

    再来看一下findArrayList这个函数


    /** * 查询数组 * @param array $array * @param int $length * @param string $field * @param $string $html' target='_blank'>value * @return array **/function findArrayList($array, $length = null, $field = null, $value = null){	if(!is_array($array)){		return $array;	}	$new_arr = array();	if(!is_null($field)){		foreach ($array as $k=>$v){			if($array[$k][$field] == $value){				$new_arr[$k] = $v;			}		}		if(empty($new_arr)){			return ;		}	}	if(empty($new_arr)){		$new_arr = $array;	}	if(!is_null($length)){		$new_arr = array_slice($new_arr,0,$length);//取出数组中指定的长度	}	return $new_arr;}

    不知道还有什么好的方法来提高从页面查询的速度。

    解释一下其中的:array_slice 从数组中取出一段

    array array_slice ( array array, int offset [, int length [, bool preserve_keys]] )

    array_slice() 返回根据 offset 和 length 参数所指定的 array 数组中的一段序列。

    如果 offset 非负,则序列将从 array 中的此偏移量开始。如果 offset 为负,则序列将从 array 中距离末端这么远的地方开始。

    如果给出了 length 并且为正,则序列中将具有这么多的单元。如果给出了 length 并且为负,则序列将终止在距离数组末端这么远的地方。如果省略,则序列将从 offset 开始一直到 array 的末端。

    注意 array_slice() 默认将重置数组的键。自 PHP 5.0.2 起,可以通过将 preserve_keys 设为 TRUE 来改变此行为 www.it165.net

    还有一个相对应的 array_splice 把数组中的一部分去掉并用其它值取代

    array array_splice ( array &input, int offset [, int length [, array replacement]] )

    array_splice() 把 input 数组中由 offset 和 length 指定的单元去掉,如果提供了 replacement 参数,则用 replacement 数组中的单元取代。返回一个包含有被移除单元的数组。注意 input 中的数字键名不被保留。

    如果 offset 为正,则从 input 数组中该值指定的偏移量开始移除。如果 offset 为负,则从 input 末尾倒数该值指定的偏移量开始移除。

    如果省略 length,则移除数组中从 offset 到结尾的所有部分。如果指定了 length 并且为正值,则移除这么多单元。如果指定了 length 并且为负值,则移除从 offset 到数组末尾倒数 length 为止中间所有的单元。小窍门:当给出了 replacement 时要移除从 offset 到数组末尾所有单元时,用 count($input) 作为 length。

    如果给出了 replacement 数组,则被移除的单元被此数组中的单元替代。如果 offset 和 length 的组合结果是不会移除任何值,则 replacement 数组中的单元将被插入到 offset 指定的位置。注意替换数组中的键名不保留。如果用来替换的值只是一个单元,那么不需要给它加上 array(),除非该单元本身就是一个数组。


    PHP编程

    郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。

  • 发表评论 共有条评论
    用户名: 密码:
    验证码: 匿名发表