目次
ディスカッションへの返信 (解決策)
ホームページ バックエンド開発 PHPチュートリアル php でページを変更すると、シリアル番号が再び始まります。

php でページを変更すると、シリアル番号が再び始まります。

Jun 23, 2016 pm 02:22 PM

php php ページ変更後のシリアル番号の問題

$MYSQL->query("select cu.*,cy.name from customer cu,custtype cy where 1=1 and cu.code=cy . コード制限 0,18");
for($i=1;$i $MYSQL->fetch($i);
$customerid=$MYSQL->data[ customerid ]; // 顧客番号
$KSName=$MYSQL->data[KSName] // ユーザー名 - 略語
echo "$i";シリアル番号
echo "$customerid"; //顧客 ID
echo "$KSName";ユーザー名 - 略語
?>

18 レコードごとに 1 ページを変更します。最初のページではシリアル番号は 1 ~ 18 ですが、2 ページ目に切り替えるとシリアル番号は 1 ~ 18 から始まります。 3ページでも同様です。ページネーションをしていない場合は問題ありませんが、ここでページネーションを行わないことは不可能です。この問題を解決します。 。




ディスカッションへの返信 (解決策)

limit 0,18
ここでの最初の制限は常に 0 であり、これはもちろん結果です

limit 0,18 これは、ここで渡されるページング パラメーターである必要があります。

for($i=1;$i echo "$i"; //シリアル番号

あなたのシリアル番号はプログラムはもちろん全て1からのスタートです

上記の回答は、ページを変更しても内容が変わらない問題を解決するためのものです
シリアル番号をやり直す問題は解決できません

つまり、解決方法ですページを変更すると、シリアル番号が 1 から 18 のように最初のページの最後のシリアル番号から始まり、2 ページ目のシリアル番号が 19 から始まる問題。また1から始めるのではなく。 。

皆さんが挙げた理由は私には分かりません。

必要なページ番号が $_GET['page'] によって渡されたと仮定すると、

$offs = 18 * isset($_GET['page']) ? $_GET['page'] - 1 : 0;$MYSQL->query("select cu.*,cy.name from customer cu,custtype cy where 1=1 and cu.code=cy.code limit $offs,18");for($i=$offs+1;$i<$offs+$count;$i++){ $MYSQL->fetch($i);	$customerid=$MYSQL->data[customerid];  // 客户编号$KSName=$MYSQL->data[KSName];  //  用户名称 - 简称echo "<td align='center'>$i</td>"; //序号echo "<td align='center'>$customerid</td>";  // 客户编号echo "<td align='center'>$KSName</td>"; //用户名称 - 简称
ログイン後にコピー

6 階にいる兄弟に返信すると、まだ機能していないようです、

と思います。モデレーターの方法で問題ありません。まず方法を見つけてください。ページ番号を $offs に渡してから、6# の指示に従ってください。

変数を個別に設定し、シリアル番号を計算する

function toolkit_pages($page, $total, $phpfile, $pagesize = 3, $pagelen = 3, $link = "&") {		$num_t_count = $total;		$phpfile = "index.php?" . $phpfile;		$pagecode = ''; //定义变量,存放分页生成的HTML		$page = intval ( $page ); //避免非数字页码		$total = intval ( $total ); //保证总记录数值类型正确		if (! $total)			return array (); //总记录数为零返回空数组		$pages = ceil ( $total / $pagesize ); //计算总分页		//处理页码合法性		if ($page < 1)			$page = 1;		if ($page > $pages)			$page = $pages;			//计算查询偏移量		$offset = $pagesize * ($page - 1);		//页码范围计算		$init = 1; //起始页码数		$max = $pages; //结束页码数		$pagelen = ($pagelen % 2) ? $pagelen : $pagelen + 1; //页码个数		$pageoffset = ($pagelen - 1) / 2; //页码个数左右偏移量				//生成html		$pagecode = '<div class="page"><span>' . $total . "</span> ";		$pagecode .= "<span>$page/$pages</span> "; //第几页,共几页		//如果是第一页,则不显示第一页和上一页的连接		if ($page != 1) {			$pagecode .= "<a href=\"{$phpfile}" . $link . "page=1\"><<</a> "; //第一页			$pagecode .= "<a href=\"{$phpfile}" . $link . "page=" . ($page - 1) . "\">Prev</a> "; //上一页		}		//分页数大于页码个数时可以偏移		if ($pages > $pagelen) {			//如果当前页小于等于左偏移			if ($page <= $pageoffset) {				$init = 1;				$max = $pagelen;			} else { //如果当前页大于左偏移				//如果当前页码右偏移超出最大分页数				if ($page + $pageoffset >= $pages + 1) {					$init = $pages - $pagelen + 1;				} else {					//左右偏移都存在时的计算					$init = $page - $pageoffset;					$max = $page + $pageoffset;				}			}		}		//生成html		for($i = $init; $i <= $max; $i ++) {			if ($i == $page) {				$pagecode .= '<span>' . $i . '</span> ';			} else {				$pagecode .= "<a href=\"{$phpfile}" . $link . "page={$i}\">$i</a> ";			}		}		if ($page != $pages) {			$pagecode .= "<a href=\"{$phpfile}" . $link . "page=" . ($page + 1) . "\">Next</a> "; //下一页			$pagecode .= "<a href=\"{$phpfile}" . $link . "page={$pages}\">>></a> "; //最后一页		}		$pagecode .= '</div>';				return array ('pagecode' => $pagecode, 'sqllimit' => ' limit ' . $offset . ',' . $pagesize );		}//引用说明/*分页列表*/		if (url_get ( 'count_page' ) != '') {			$count_page = url_get ( 'count_page' );		} else {			$count_page = 15;		}		if (url_get ( 'page' ) <= 0 || url_get ( 'page' ) == '') {			$page = 1;		} else {			$page = url_get ( 'page' );		}		$t_count = $this->Cmspage_model->row_array ();//统计记录个数自己写个sql语句		$t_first = ($page - 1) * $count_page;		$list = $this->Cmspage_model->result_array ( $t_first, $count_page );//返回数组自己写个sql语句		//引用分页函数		$getpageinfo = toolkit_pages ( $page, $t_count, "?c=page&m=index", $count_page, 8 );
ログイン後にコピー

#10 ルー兄弟がページング コードを書いたようですが、これは私の問題とはあまり関係がないようです。

神様に解決してください。 。 。 。 。 。 。 。 。 。 。 。 。 。 。 。 。 。 。 。

神様に解決してください。 。 。 。 。 。 。 。 。 。 。 。 。 。 。 。 。 。 。 。

フロア 6 はすでに解決していますが、完全なコードを書くのを他の人に頼むことはできません。 SQL ステートメントでの制限の使用法に注目してください。どうやって技術スコアが800点を超えたのですか?あなたは私たちをからかうためにここにいます。 。 。 。 。

#14、兄弟、問題が理解できないなら、ナンセンスなことを言わないでください。 。 OK!!!!!!!!

#14、兄弟、問題が理解できないなら、ナンセンスなことを言わないでください。 。 ok!!!!!!!!
ページ番号を変更するときは、$_GET['page']; のように、URL から渡された $page 値を取得する必要があります。その後、それぞれに対して 1 つずつ取得します。ページには $page_size があり、$page_size=18;
したがって、ページに表示するときのリストの ID 番号は次のようになります: ($page-1)*$page_size+$i;配列の添字。

$page=$_GET['page'];$page_size=18;$count=$MYSQL->query("select count(*) from customer cu,custtype cy where 1=1 and cu.code=cy.code");$pages = ceil($count/$page_size);if($page<1) $page = 1;if($page>$pages)$page = $pages;$offset = ($page-1) * $page_size;if($offset<0) $offset = 0;$MYSQL->query("select cu.*,cy.name from customer cu,custtype cy where 1=1 and cu.code=cy.code  limit ".$offset.",".$page_size);for($i=1;$i<$count;$i++){	$MYSQL->fetch($i);		$customerid=$MYSQL->data['customerid'];  // 客户编号	$KSName=$MYSQL->data['KSName'];  //  用户名称 - 简称	$thisPage=($page-1).$page_size+$i;	echo "<td align='center'>".$thisPage."</td>"; //序号	echo "<td align='center'>$customerid</td>";  // 客户编号	echo "<td align='center'>$KSName</td>"; //用户名称 - 简称}
ログイン後にコピー


$MYSQL オブジェクトの具体的な状況がわからないので、

$thisPage=($page-1).$page_size+$i;

この文に焦点を当てて別の場所でアイデアを考えます。

訂正します。これは編集できません。$thisPage=($page-1)*$page_size+$i;

そうですね、#16 ルー兄弟が正しいです。 。本当にありがとうございます

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 JSON Web Tokens(JWT)とPHP APIでのユースケースを説明してください。 Apr 05, 2025 am 12:04 AM

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

確固たる原則と、それらがPHP開発にどのように適用されるかを説明してください。 確固たる原則と、それらがPHP開発にどのように適用されるかを説明してください。 Apr 03, 2025 am 12:04 AM

PHP開発における固体原理の適用には、次のものが含まれます。1。単一責任原則(SRP):各クラスは1つの機能のみを担当します。 2。オープンおよびクローズ原理(OCP):変更は、変更ではなく拡張によって達成されます。 3。Lischの代替原則(LSP):サブクラスは、プログラムの精度に影響を与えることなく、基本クラスを置き換えることができます。 4。インターフェイス分離原理(ISP):依存関係や未使用の方法を避けるために、細粒インターフェイスを使用します。 5。依存関係の反転原理(DIP):高レベルのモジュールと低レベルのモジュールは抽象化に依存し、依存関係噴射を通じて実装されます。

システムの再起動後にUnixSocketの権限を自動的に設定する方法は? システムの再起動後にUnixSocketの権限を自動的に設定する方法は? Mar 31, 2025 pm 11:54 PM

システムが再起動した後、UnixSocketの権限を自動的に設定する方法。システムが再起動するたびに、UnixSocketの許可を変更するために次のコマンドを実行する必要があります:sudo ...

PHPにおける後期静的結合の概念を説明します。 PHPにおける後期静的結合の概念を説明します。 Mar 21, 2025 pm 01:33 PM

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

PHPのCurlライブラリを使用してJSONデータを含むPOSTリクエストを送信する方法は? PHPのCurlライブラリを使用してJSONデータを含むPOSTリクエストを送信する方法は? Apr 01, 2025 pm 03:12 PM

PHP開発でPHPのCurlライブラリを使用してJSONデータを送信すると、外部APIと対話する必要があることがよくあります。一般的な方法の1つは、Curlライブラリを使用して投稿を送信することです。

フレームワークセキュリティ機能:脆弱性から保護します。 フレームワークセキュリティ機能:脆弱性から保護します。 Mar 28, 2025 pm 05:11 PM

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。

フレームワークのカスタマイズ/拡張:カスタム機能を追加する方法。 フレームワークのカスタマイズ/拡張:カスタム機能を追加する方法。 Mar 28, 2025 pm 05:12 PM

この記事では、フレームワークにカスタム機能を追加し、アーキテクチャの理解、拡張ポイントの識別、統合とデバッグのベストプラクティスに焦点を当てています。

See all articles