---
layout: post
title: 像查询SQL一样操作数组的PHP类
description: 从数据的角度看,后台语言都是在操作数据的各种变化,而数组是堆数据最重要的呈现方式,所以我们需要记住一定的操作数组的函数,而使用内置提供的函数目的,就在于避免重复造轮子,提高开发的效率
keywords: PHP,数组查询,搜索数组,sql like
author: admin
date: 2023-01-19 09:49
category: 网络技术
tags: php
---

**SQL全称** : **Structured Query Language** ,简单理解为数据库(Database)管理系统,可以访问和处理数据库,如:数据查询。SQL也是有自己的一套语法,用关键字、表名、列名等组合而成的一条语句,语法其实不难,熟知后会觉得和英语语法逻辑有点类似。从数据的角度看,后台语言都是在操作数据的各种变化,而数组是堆数据最重要的呈现方式,所以我们需要记住一定的操作数组的函数,而使用内置提供的函数目的,就在于避免重复造轮子,提高开发的效率。嗨网HiGrid.Net提供一个 **类似操作SQL** 一样的类供 **选择查询php数组** 并 **提供源代码** ,希望能有用。

## HiGridArray 查询方式

### 加载类HiGridArray,实例化

```php

$conn = new HiGridArray();

$conn->query ("SQL查询语句");

/*
higrid_blog_array为嗨网HIGrid.net博客二维数组,结构包括文章头部的meta文件,如:

layout: post
title: XXX
description: XXX
keywords: xxx
author: admin
date: 2023-01-19 09:49
category: 网络技术
tags: php

*/

```

更多信息详见:[hicms介绍](/posts/hicms.html)


### 利用HiGrid.net Blog文章数据演示像SQL一样操作数组

```php

//1.产生所有存档文件
$archives=$conn->query ("SELECT * FROM higrid_blog_array ORDER BY date DESC");

//1.最新10篇文章
$archives_ten=$conn->query ("SELECT * FROM higrid_blog_array limit 10 ORDER BY date DESC");
file_put_contents(DATA_AUTO.'archives_ten.txt', serialize($archives_ten));

//类别-嗨网文档
$cats_wendang=$conn->query ("SELECT * FROM higrid_blog_array where category LIKE '%嗨网文档%' ORDER BY date DESC");

```

### HiGridArray 源代码

[ HiGridArray 源代码](/show/p/higridarray)

## PHP常用操作数组的函数
### PHP常用操作数组:变量与数组的转换

compact() 将变量以变量名的方式组装成数组

```php
$bianliang1 = '赵';
$bianliang2 = '锐';
$arr = compact('bianliang1','bianliang2');
//返回的结果为
['bianliang1'=>'赵','bianliang2'=>'锐'];
//应用场景1
在TP、Laravel中将查询出来的数据向末班引擎中添加的时候会用到..
```

extract() 将数组解析成变量/ 和compact是反转的

```php
$arr = ['bianliang1'=>'赵','bianliang2'=>'锐'];
extract($arr);
//使用-输出bianliang1(相当于你声明了一次变量,有点向ES6解构赋值的意思)
echo $bianliang1;
```

### PHP常用操作数组:变量和字符串的转换

```php
$str = '热爱,喜欢,兴奋';
$arr = explode(',',$str);//表示以字符串中的逗号分隔成数组
//结果为
['热爱','喜欢','兴奋'];
```

如果解析的字符串是个空字符串,结果是一个数组有一个索引为0的值,值为空;并不是个空数组;

```php
$arr = ['热爱','喜欢','兴奋'];
//将数组解析成字符串
$str = implode(',',$arr);
//得到的结果为
'热爱,喜欢,兴奋'
```

### PHP常用操作数组:数组和数组之间关系

并集关系

```php
$arr1 = ['赵','上','的'];
$arr2 = ['张','赵'];
//将2个数组合并
$arr_mer = array_merge($arr1,$arr2);
//结果为
['赵','上','的','张','赵']
```

差集关系

```php
$arr1 = ['赵','上','的'];
$arr2 = ['张','赵'];
//获取第一个数组在第二个数组中的差集部分,就是没有的部分
$arr_dif = array_diff($arr1,$arr2);
//结果为
['上','的']
```

交集关系

```php
$arr1 = ['赵','上','的'];
$arr2 = ['张','赵'];
//获取2个数组相交集的部分数组
$arr_inter = array_intersect($arr1,$arr2);
//结果为
['赵']
```

### PHP常用操作数组:数组值的操作

删除数组最后一个值

```php
$arr = ['赵','上','的'];
array_pop($arr);//删除数组最后一个值
//结果为
['赵','上']
```

向数组中追加一个值

```php
$arr = ['赵','上','的'];
array_push($arr,'王');//支持多个参数,比如第三个参数 仍然会被追加到数组中去
//得到结果为: (array_push不需要接收,直接引用操作原数组)
echo $arr;
['赵','上','的','王'];
```

### PHP常用操作数组:判断值是否存在数组中

判断值是否存在数组中

```php
$arr = ['name'=>'嗨网','age'=>18,'class'=>'大班'];
$bol = in_array('嗨网',$arr);//如果存在返回true 否则返回false
//得到结果为true
```

判断键是否存在数组中

```php
$arr = ['name'=>'嗨网','age'=>18,'class'=>'大班'];
$bol = array_key_exists('name',$arr);//如果值存在返回true,否则返回false
//得到结果为true
```

### PHP常用操作数组:数组去重

数组去重

```php
$arr = ['赵','赵','锐'];
$arr_uni = array_unique($arr);//数组去重
//得到的结果为
['赵','锐']
```

### PHP常用操作数组:获取二维数组中值的集合

```php
$arr = [
['name'=>'嗨网','id'=>'one','school'=>'higridnet'],
['name'=>'孙悟空','id'=>'two','school'=>'higridnet'],
['name'=>'刘德华','id'=>'three','school'=>'higridnet'],
['name'=>'朱德','id'=>'four','school'=>'higridnet'],
];
//提取name为键的值构成一维数组
$arr_colu = array_column($arr,'name');
//得到结果
['嗨网','孙悟空','刘德华','朱德']
//提取那么为键的值切提取对应数组红的id值作为键构成一维键值数组
$arr_colu = array_column($arr,'name','id');
['one'=>'嗨网','two'=>'孙悟空','three'=>'刘德华','four'=>'朱德']
```

### PHP常用操作数组:提取数组的键与值

获取数组的键

```php
$arr = ['name'=>'嗨网','id'=>'one','school'=>'higridnet'];
$arr_val = array_values($arr);//提取数组中的值
//得到的结果为
['嗨网','one','higridnet'];
```

获取数组的值

```php
$arr = ['name'=>'嗨网','id'=>'one','school'=>'higridnet'];
$arr_key = array_keys($arr);//提取数组中键的集合
//得到结果为
['name','id','school'];
```

### PHP常用操作数组:返回数组中值的和

返回数组中值的和

```php
$arr = ['name'=>'嗨网','id'=>'one','school'=>'higridnet'];
$number = count($arr);
//返回的结果
3
```

### PHP常用操作数组:回数组随机的键

```php
$arr = ['name'=>'嗨网','id'=>'one','school'=>'higridnet'];
$number = array_rand($arr);
//返回的结果
'id'
```

### PHP常用操作数组:搜索值是否存在数组中

```php
$arr = ['name'=>'嗨网','id'=>'one','school'=>'higridnet'];
$is = array_search('嗨网'=>$arr);
//返回的结果
'name'
```

### PHP常用操作数组:多维数组进行排序

```text
/*
上面讲的数组排序都是指的一个整体数组,索引数组升序降序等等或者关联数组根据键值对的升序或者排序;
而这里将的排序是一个数组收到其他数组的影响进行排序;其实这种方式就如同对数据库的数据进行升降排序的道理是一致的;
*/
$guys = array(
array('name'=>'jake', 'score'=>80, 'grade' =>'A'),
array('name'=>'jina', 'score'=>70, 'grade'=>'A'),
array('name'=>'john', 'score'=>30, 'grade' =>'A'),
array('name'=>'sss', 'score'=>70, 'grade'=>'C'),
array('name'=>'ben', 'score'=>20, 'grade'=>'B')
);
//如上有一个数组,要求根据score字段升序,相同的情况下根据name字段排序;
$score = array_column($guys,”score”);
$score = array_column($guys,”name”);
Array_multisort($score,SORT_ASC,$name,SORT_DESC,$guys );
```


## PHP数组常用函数分类整理

### 数组操作的基本函数

```text
数组的键名和值
array_values($arr); 获得数组的值
array_keys($arr); 获得数组的键名
array_flip($arr); 数组中的值与键名互换(如果有重复前面的会被后面的覆盖)
in_array("apple",$arr); 在数组中检索apple
array_search("apple",$arr); 在数组中检索apple ,如果存在返回键名
array_key_exists("apple",$arr); 检索给定的键名是否存在数组中
isset($arr[apple]): 检索给定的键名是否存在数组中

数组的内部指针
current($arr); 返回数组中的当前单元
pos($arr); 返回数组中的当前单元
key($arr); 返回数组中当前单元的键名
prev($arr); 将数组中的内部指针倒回一位
next($arr); 将数组中的内部指针向前移动一位
end($arr); 将数组中的内部指针指向最后一个单元
reset($arr; 将数组中的内部指针指向第一个单元
each($arr); 将返回数组当前元素的一个键名/值的构造数组,并使数组指针向前移动一位
list($key,$value)=each($arr); 获得数组当前元素的键名和值

数组和变量之间的转换
extract($arr);用于把数组中的元素转换成变量导入到当前文件中,键名当作变量名,值作为变量值
注:(第二个参数很重要,可以看手册使用)使用方法 echo $a;
compact(var1,var2,var3);用给定的变量名创建一个数组
```

### 数组的分段和填充

```text
数组的分段
array_slice($arr,0,3); 可以将数组中的一段取出,此函数忽略键名
array_splice($arr,0,3,array("black","maroon")); 可以将数组中的一段取出,与上个函数不同在于返回的序列从原数组中删除

分割多个数组
array_chunk($arr,3,TRUE); 可以将一个数组分割成多个,TRUE为保留原数组的键名

数组的填充
array_pad($arr,5,'x'); 将一个数组填补到制定长度
```

### 数组与栈

```text
array_push($arr,"apple","pear"); 将一个或多个元素压入数组栈的末尾(入栈),返回入栈元素的个数
array_pop($arr); 将数组栈的最后一个元素弹出(出栈)
```

### 数组与列队

```text
array_shift($arr);数组中的第一个元素移出并作为结果返回(数组长度减1,其他元素向前移动一位,数字键名改为从零技术,文字键名不变)
array_unshift($arr,"a",array(1,2));在数组的开头插入一个或多个元素
```

### 回调函数

```text
array_walk($arr,'function','words'); 使用用户函数对数组中的每个成员进行处理(第三个参数传递给回调函数function)
array_mpa("function",$arr1,$arr2); 可以处理多个数组(当使用两个或更多数组时,他们的长度应该相同)
array_filter($arr,"function"); 使用回调函数过滤数组中的每个元素,如果回调函数为TRUE,数组的当前元素会被包含在返回的结果数组中,数组的键名保留不变
array_reduce($arr,"function","*"); 转化为单值函数(*为数组的第一个值)
```

### 数组的排序

```text
通过元素值对数组排序
sort($arr); 由小到大的顺序排序(第二个参数为按什么方式排序)忽略键名的数组排序
rsort($arr); 由大到小的顺序排序(第二个参数为按什么方式排序)忽略键名的数组排序
usort($arr,"function"); 使用用户自定义的比较函数对数组中的值进行排序(function中有两个参数,0表示相等,正数表示第一个大于第二个,负数表示第一个小于第二个)忽略键名的数组排序
asort($arr); 由小到大的顺序排序(第二个参数为按什么方式排序)保留键名的数组排序
arsort($arr); 由大到小的顺序排序(第二个参数为按什么方式排序)保留键名的数组排序
uasort($arr,"function"); 使用用户自定义的比较函数对数组中的值进行排序(function中有两个参数,0表示相等,正数表示第一个大于第二个,负数表示第一个小于第二个)保留键名的数组排序

通过键名对数组排序
ksort($arr); 按照键名正序排序
krsort($arr); 按照键名逆序排序
uksort($arr,"function"); 使用用户自定义的比较函数对数组中的键名进行排序(function中有两个参数,0表示相等,正数表示第一个大于第二个,负数表示第一个小于第二个)

自然排序法排序
natsort($arr); 自然排序(忽略键名)
natcasesort($arr); 自然排序(忽略大小写,忽略键名)
```

### 数组的计算

```text
数组元素的求和
array_sum($arr); 对数组内部的所有元素做求和运算

数组的合并
array_merge($arr1,$arr2); 合并两个或多个数组(相同的字符串键名,后面的覆盖前面的,相同的数字键名,后面的不会做覆盖操作,而是附加到后面)
“+”$arr1+$arr2; 对于相同的键名只保留后一个
array_merge_recursive($arr1,$arr2); 递归合并操作,如果数组中有相同的字符串键名,这些值将被合并到一个数组中去。如果一个值本身是一个数组,将按照相应的键名把它合并为另一个数组。当数组 具有相同的数组键名时,后一个值将不会覆盖原来的值,而是附加到后面

数组的差集
array_diff($arr1,$arr2); 返回差集结果数组
array_diff_assoc($arr1,$arr2,$arr3); 返回差集结果数组,键名也做比较

数组的交集
array_intersect($arr1,$arr2); 返回交集结果数组
array_intersect_assoc($arr1,$arr2); 返回交集结果数组,键名也做比较
```

### 其他的数组函数

```text
range(0,12); 创建一个包含指定范围单元的数组
array_unique($arr); 移除数组中重复的值,新的数组中会保留原始的键名
array_reverse($arr,TRUE); 返回一个单元顺序与原数组相反的数组,如果第二个参数为TRUE保留原来的键名
//srand((float)microtime()*10000000); 随机种子触发器
array_rand($arr,2); 从数组中随机取出一个或 多个元素
shuffle($arr); 将数组的顺序打乱
```