2 つの異なるテーブルのページングを実装する
php メソッド: 1. PHP サンプル ファイルを作成します; 2. 「function getPage($a, $b, $page, $page_size){...}」を通じてそれを実装します。 「テーブル間でページネーションするだけです。
#php 2 つの異なるテーブルのページングを実現するにはどうすればよいですか?
PHP クロステーブル ページング2 つのテーブルのデータが比較的バランスがとれている場合に適しています<?php function getPage($a, $b, $page, $page_size){ sort($a); sort($b); $total_a = count($a); $total_b = count($b); $averge = floor($page*$page_size/2); $a_f = array_slice($a, $averge, $page_size); # 升序序列 first $b_f = array_slice($b, $averge, $page_size); # 升序序列 $a_f_len = count($a_f); $b_f_len = count($b_f); $min_a = $a_f[0] ?? null; $min_b = $b_f[0] ?? null; $max_a = $a_f[$a_f_len-1] ?? null; $max_b = $b_f[$b_f_len-1] ?? null; if (empty($a_f)) { $min = $min_b; $a_s = getRangeInfo($a, $min_b, $max_a); $offset = count($a_s)+ ($averge-$total_a); } if (empty($b_f)) { $min = $min_a; $b_s = getRangeInfo($a, $min_a, $max_b); $offset = count($b_s)+ ($averge-$total_b); } if (!empty($a_f) && !empty($b_f)) { $min = min([$min_a, $min_b]); if($min_a > $min_b || empty($b_f)) # b组数据小 重新查询a组 { # 查出偏移量 # 第二次查询 second $a_s = getRangeInfo($a, $min, $max_a); # second 第二次查找 # 求出新查出的数据与最开始查出a数组相差个数 $offset = count($a_s)-$a_f_len; } else { # a组数据小 重新查询b组 # 查出偏移量 $b_s = getRangeInfo($b, $min, $max_b); # 求出新查出的数据与最开始查出a数组相差个数 $offset = count($b_s)-$b_f_len; } } $now_position = $show = (int)($averge*2-$offset); $start_position = $page*$page_size; $end_position = ($page+1)*$page_size-1; // 假如一次查询某数组为空,查询的第二组数据未能涵盖所需全部数据,故重新查询 $a_s = getlimit($a, $min, $start_position-$now_position+$page_size); $b_s = getlimit($b, $min, $start_position-$now_position+$page_size); $total_arr = array_merge($a_s, $b_s) ; sort( $total_arr); # 升序排列 $res = []; foreach ($total_arr as $k=>$v) { if ($now_position > $end_position) { break; } if ($now_position < $start_position){ $now_position = $now_position+1; continue; } $now_position = $now_position+1; $res[] = $v; } // 思路如下: $min_str = $min_a > $min_b ? ' 最小数在b, 重新获取a数据'.json_encode($a_s):'最小数在a, 重新获取b数据'.json_encode($b_s); print_r('数组$a:'.json_encode($a)); echo '<br>'; print_r('数组$b:'.json_encode($b)); echo '<br>'; print_r('平均数floor is '.$averge.', $a 最小值是 '.$min_a.',$b 最小值是 '.$min_b.', 对比之后得出最小值是'.$min.','.$min_str. '此时偏移量'.$offset.', 最小数'.$min.'处于位置'.$show.', 我需要'.$start_position.'到'.$end_position.'的数据, 查出所需数据为'.json_encode($total_arr).', 结果为'.json_encode($res)); return $res;}// 按值范围获取function getRangeInfo ($array, $start_value, $end_value){ sort($array); $res = []; foreach ($array as $k => $v) { if ($v >= $start_value && $v <= $end_value){ $res[] = $v; } } return $res;}// 按起始位置个数获取function getlimit ($array, $start_value, $num){ sort($array); $res = []; foreach ($array as $k => $v) { if ($num<=0) { break; } if ($v >= $start_value){ $res[] = $v; $num --; } } return $res;}$b = [1];$a = [2,3,1,4,5,6,7,8,9,10,12,14];$page = 2; # 第一页$page_size = 5;$list = getPage($a, $b, $page, $page_size);$all = array_merge($a, $b);sort($all);echo '<br>';echo '<br>';echo '<br>';$start_position = $page*$page_size;$real = array_slice($all, $start_position, $page_size);print_r('合并总数据'.json_encode($all).',一页'.$page_size.'条, 第'.(string)($page+1).'页数据为:'.json_encode($real));
PHP ビデオ チュートリアル 」
以上がPHPで2つの異なるテーブル間にページネーションを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、酸とベースのデータベースモデルを比較し、その特性と適切なユースケースを詳述しています。酸は、財務およびeコマースアプリケーションに適したデータの整合性と一貫性を優先し、ベースは可用性に焦点を当て、

この記事では、コードインジェクションのような脆弱性を防ぐために、PHPファイルのアップロードを確保することについて説明します。ファイルタイプの検証、セキュアストレージ、およびアプリケーションセキュリティを強化するエラー処理に焦点を当てています。

記事では、組み込み関数、ホワイトリストアプローチ、サーバー側の検証などの手法に焦点を当てたセキュリティを強化するためのPHP入力検証のベストプラクティスについて説明します。

この記事では、Token BucketやLeaky BucketなどのアルゴリズムやSymfony/Rate-Limiterなどのライブラリを使用するなど、PHPでAPIレート制限を実装するための戦略について説明します。また、監視、動的に調整されたレートの制限、および手をカバーします

この記事では、パスワードを保護するためにPHPでpassword_hashとpassword_verifyを使用することの利点について説明します。主な議論は、これらの関数が自動塩の生成、強力なハッシュアルゴリズム、およびSecurを通じてパスワード保護を強化するということです

この記事では、PHPおよび緩和戦略におけるOWASPトップ10の脆弱性について説明します。重要な問題には、PHPアプリケーションを監視および保護するための推奨ツールを備えたインジェクション、認証の壊れ、XSSが含まれます。

この記事では、PHPでのXSS攻撃を防ぐための戦略について説明し、入力の消毒、出力エンコード、セキュリティを向上させるライブラリとフレームワークの使用に焦点を当てています。

この記事では、PHPでのインターフェイスと抽象クラスの使用について説明し、それぞれをいつ使用するかに焦点を当てています。インターフェイスは、無関係なクラスや複数の継承に適した、実装なしで契約を定義します。抽象クラスは共通の機能を提供します


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

メモ帳++7.3.1
使いやすく無料のコードエディター
