国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

PHP將兩個關聯數組合并函數提高函數效率

2024-05-04 23:22:16
字體:
來源:轉載
供稿:網友
在foreach中循環查詢數據代碼量比較少,但是性能比較低,好點的解決辦法是將id收集起來,用in一次性查詢,但是這引發了數據結構不是我們用PHP自帶的函數可以合并的,今天測試了一下:

使用下面的字節寫的函數可以解決

從數據庫中取出來的數據總是或多或少不符合我們心目中的數據結構,類似于下面的倆個數組,要形成SQL中類似于left join后兩個數組合并:

復制代碼 代碼如下:


$test1 = Array(
0 => Array(
'id' => 9478137,
'create_time' => 1394760724
),
1 => Array(
'id' => 9478138,
'create_time' => 1394760725
),
2 => Array(
'id' => 9478138,
'create_time' => 1394760725
)
);
$test2 = array(
0 => array(
'id' => 9478137,
'message' => 'love you'
),
1 => array(
'id' => 9478138,
'message' => 'miss you'
)
);


如果要將這兩個數組,類似于sql中的left join 關聯起來我們用什么函數呢?額我沒有找見就自己寫了
剛開始的時候,用的是嵌套循環:效率低下

復制代碼 代碼如下:


function _mergerArray($array1, $array2, $field1, $field2 = '') {
$ret = array();
foreach($array1 as $key1 => $value1 ) {
foreach ($array2 as $key2 => $value2) {
if($value1[$field1] == $value2[$field2]) {
$ret[$key1] = array_merge($value1, $value2);
}
}
}
return $ret;
}


改進后的辦法,使用數組下標,使用兩次循環:形成類似于left join的方式

復制代碼 代碼如下:


$test1 = Array(
0 => Array(
'id' => 9478137,
'create_time' => 1394760724
),
1 => Array(
'id' => 9478138,
'create_time' => 1394760725
),
2 => Array(
'id' => 9478138,
'create_time' => 1394760725
)
);
$test2 = array(
0 => array(
'id' => 9478137,
'message' => 'love you'
),
1 => array(
'id' => 9478138,
'message' => 'miss you'
)
);

function _mergerArray($array1, $array2, $field1, $field2 = '') {
$ret = array();

//使用數組下標的辦法
foreach ($array2 as $key => $value) {
$array3[$value[$field1]] = $value;
}
foreach ($array1 as $key => $value) {
$ret[] = array_merge($array3[$value[$field1]], $value);
}
return $ret;
}
$ret = _mergerArray($test1, $test2, 'id', 'id');
print_r($ret);exit;


打印出來結果如下:

復制代碼 代碼如下:


Array
(
[0] => Array
(
[id] => 9478137
[message] => love you
[create_time] => 1394760724
)
[1] => Array
(
[id] => 9478138
[message] => miss you
[create_time] => 1394760725
)
[2] => Array
(
[id] => 9478138
[message] => miss you
[create_time] => 1394760725
)
)


相當于left join了吧?
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 滦南县| 虎林市| 霍州市| 申扎县| 兴业县| 襄汾县| 鲜城| 靖远县| 惠州市| 辽阳县| 隆回县| 布尔津县| 大冶市| 吉水县| 治县。| 南京市| 万安县| 巨鹿县| 华蓥市| 黎平县| 普格县| 高淳县| 麦盖提县| 中方县| 镇江市| 噶尔县| 偃师市| 鹿泉市| 长宁县| 灵丘县| 恩施市| 万山特区| 万全县| 新巴尔虎左旗| 佛山市| 通海县| 周宁县| 林西县| 宣汉县| 临城县| 无棣县|