(データベースなどから取得した)多次元配列の値と、一次元配列を比較して、「一致」及び「増減」を返す

配列

 閲覧数:1038  投稿日:2020-02-18  更新日:2020-02-26  

存在している値を比較する
・等しい … trueを返す
・減少
・増加


※キーは関係ない


-----------------------------------
返ってきた後
空の配列をforeachすると、

<?php
foreach(array() as $a) {
print_r('hoge' . PHP_EOL);
}
エラー出力されない。何も出力されない


コード

<?php
function diff($data,$post)
{
    $pickAry = array_column($data,"tag_id","id");//DB取得データよりarray(id => tag_id)を抽出
    var_export($pickAry);

    $del = array_diff($pickAry,$post);
    $ins = array_diff($post,$pickAry);

    //if(!empty($del)) $del = array_keys($del); //キーを値として取得したい場合に使用。キーは新たに振り直される
    //if(!empty($ins)) $ins = array_values($ins); //(値を値として取得したい場合に使用。)キーが新たに振り直される
    
    if(empty($del)&&empty($ins)) return TRUE;
    //
    return array($del,$ins);
}
//存在している値は等しい、キーは関係ない
$dbAry = [
  [ 'id' => '2',
    'entry_id' => '1',
    'tag_id' => '3',
  ],
  [ 'id' => '1',
    'entry_id' => '1',
    'tag_id' => '2',
  ],
];
$postAry = [
  0 => '3',
  1 => '2',
];
var_export(diff($dbAry,$postAry));


//存在している値の増減を返す。キーは関係ない
$dbAry = [
  [ 'id' => '2',
    'entry_id' => '1',
    'tag_id' => '3',
  ],
  [ 'id' => '1',
    'entry_id' => '1',
    'tag_id' => '2',
  ],
];
$postAry = [
  8 => '2',
  7 => '9',
];
var_export(diff($dbAry,$postAry));



結果

//存在している値は等しい、キーは関係ない
array (
  2 => '3',
  1 => '2',
)
//一致
true


//存在している値の増減を返す。キーは関係ない
array (
  2 => '3',
  1 => '2',
)
//[0]減少分,[1]増加分
array (
  0 => 
  array (
    2 => '3',
  ),
  1 => 
  array (
    7 => '9',
  ),
)



タグ


array_column 





array_diffを使用して、「複数配列」間で「存在している値」を比較後、その結果を配列で返す

配列キー内に「指定文字列が含まれるキー」と「その値」を抽出して、新しい配列を返す



類似度ページランキング
順位 ページタイトル抜粋
1 (データベースなどから取得した)多次元配列の値と、一次元配列を比較して、「一致」及び「増減」を返す 78
2 (データベースなどから取得した)多次元配列の構造を変換して一次元配列を返す 60
3 多次元配列で「一次元目の最大値 +1 」 を返す 36
4 多次元配列で「二次元目の最大値 +1 」 を返す 33
5 配列のキーと値を反転した新しい配列を返す array_flip() 32
6 UNIXのタイムスタンプから日付(文字列)を取得後、「アクセスした時点の年月日時分秒」を整形して表示 … date() 31
7 配列キー内に「指定文字列が含まれるキー」と「その値」を抽出して、新しい配列を返す 31
8 文字列としてフォーマットされた配列値を返す 31
9 多次元配列キーを、多次元配列内にある「特定キーの値」へ変更 31
10 日付(文字列)から、指定時刻のUNIXタイムスタンプを取得 31
11 配列の中より、「ランダム」かつ「重複することなく」複数の値を抽出 30
12 多次元配列で「二次元目にある指定値のカウント数 +1 」 を返す 30
13 連想配列を(キーと値の関係性を維持したまま)シャッフル 29
14 array_diffを使用して、「複数配列」間で「存在している値」を比較後、その結果を配列で返す 29
15 現在のセッションクッキーのパラメータ情報を配列として返す 29
16 「二次元目の指定キーが指定値である、二次元目配列」を削除 29
17 配列のキーを取得する array_keys() 28
18 UNIXのタイムスタンプから日付(文字列)を取得後、「現在の年月日時分秒」を表示 … getdate() 28
19 多次元配列の「一次元要素数」もしくは「全次元要素数」をカウント 28
20 要素のキーと初期値を指定して配列を作成する array_fill_keys() 27
2024/4/22 0:32 更新
週間人気ページランキング / 4-14 → 4-20
順位 ページタイトル抜粋 アクセス数
1 後ろから3文字削除 / 「18:00:00」→「18:00」 | 文字列(テキスト処理) 11
2 URLから、トップページ(index.html)判定 | ルーティング 7
2 配列キー内に「指定文字列が含まれるキー」と「その値」を抽出して、新しい配列を返す | 配列(型) 7
3 「input type="datetime-local"」で受け取った文字列をハイフンへ変更 | 日付および時刻関連 5
4 指定文字列より前を取得 | 文字列(テキスト処理) 4
4 現在WebページのURLパスを第2階層まで取得 | パス 4
4 投稿日時をTwitterのように「★分前」「★時間前」という文字列変換するユーザ定義PHP関数 | 日付および時刻関連 4
4 配列の空要素を削除(コールバック関数未使用) … array_filter() | 配列(型) 4
5 多次元配列キーを、多次元配列内にある「特定キーの値」へ変更 | 多次元配列(型) 3
5 日付表示(フォーマット指定) | 日付および時刻関連 3
6 range( ) を使用して日付期間を配列生成 | 日付および時刻関連 2
6 null代入とunset()の違い | 変数 2
6 $_SERVER['REQUEST_URI'] | タグ毎エントリー一覧 2
6 対象文字列の内、「最初の指定文字列以前」と「それ以降の文字列」を取得する | 文字列(テキスト処理) 2
6 配列を変数として展開する extract() | 配列(型) 2
6 配列内容を、foreachでテーブル表示 | テーブル 2
7 PHPで最後の「指定区切り文字」より後ろを取得 | 配列(型) 1
7 配列の空要素を削除 / array_diff()で空配列と比較し配列の差分を返す | 配列(型) 1
7 n | タグ毎エントリー一覧 1
7 多次元配列の「一次元要素数」もしくは「全次元要素数」をカウント | 多次元配列(型) 1
2024/4/21 1:02 更新