助けを求めています
$sql="select * from xym_pic"
$res=mysql_query($sql,$conn); ( $row=mysql_fetch_assoc($res)){
$data[]=$row;
}// 実際の状況をシミュレートするために 9 つのレコードをランダムに選択します
$keys = array_rand($data, 10); ( );
foreach($keys as $key){
$json[] = $data[$key] }
このコードのウォーターフォール data.php 部分のコード各取得後、データはデータベースから取得され、配列 $data[] に入れられます。本来の方法では、毎回 9 つのレコードをランダムに取得し、時間順にソートして削除します。 1 回目は 0-9 で、2 回目は 10-9 というようになります。誰かデータを抽出する方法を教えてくれませんか?どうもありがとうございます!問題を解くと100点差し上げます! ! !親切な方が QQ に参加して指導していただければ幸いです: QQ 2 7 7 6 2 8 1 8 1
ディスカッション (解決策) への返信
session_start();if(! isset($_SESSION['last'])) $_SESSION['last'] = 0;$last = $_SESSION['last'];$sql="select * from xym_pic limit $last,9";$res=mysql_query($sql,$conn);while ($row=mysql_fetch_assoc($res)){ $data[]=$row;}$_SESSION['last'] += count($data);echo json_encode( $data )
返信してくれたモデレーターに感謝します。解決しました。ありがとうございます。 ! ! ! ! ! ! ! !
session_start();if(! isset($_SESSION['last'])) $_SESSION['last'] = 0;$last = $_SESSION['last'];$sql="select * from xym_pic limit $last,9";$res=mysql_query($sql,$conn);while ($row=mysql_fetch_assoc($res)){ $data[]=$row;}$_SESSION['last'] += count($data);echo json_encode( $data );
まだ小さな問題があります。つまり、データベースに 80 件以上のレコードがあり、毎回 9 回取り出しても、すべて取り出されてしまいます。ページを更新してもセッションが残っています。どうすれば解決できますか?ありがとうございます
session_start();if(! isset($_SESSION['last'])) $_SESSION['last'] = 0;$last = $_SESSION['last'];$sql="select * from xym_pic limit $last,9";$res=mysql_query($sql,$conn);while ($row=mysql_fetch_assoc($res)){ $data[]=$row;}$_SESSION['last'] += count($data);echo json_encode( $data );
まだ小さな問題があります。つまり、データベースに 80 件以上のレコードがあり、毎回 9 つのレコードを取り出しますが、それらはすべて取り出されます。ですが、ページを更新してもセッションが残っています。どうすれば解決できますか?ありがとうございます
ウォーターフォールフローはセッションに保存すべきではありませんね?リクエストパラメータでデータの先頭を判断するのはページングと同じはずです
取得できなかった場合は、もう一度最初から取得してください
取得できなかった場合は、もう一度最初から取得してください
取得できない場合は最初から取得してくださいもう一度
結果セットが空の場合はセッションを破棄すると判断しましたが、それでもデータを取得できません
結果セットが空の場合は、セッションを破棄しても、また無限ループになります
結果セットは空だと思うので、ページが更新されるまで結果は再度取得されません
解決方法
session_start();if(! isset($_SESSION['last'])) $_SESSION['last'] = 0;$last = $_SESSION['last']; $sql="select * from xym_pic limit $last,9";$res=mysql_query($sql,$conn);if(mysql_num_rows($res) ==0) { $last = $_SESSION['last'] = 0; $sql="select * from xym_pic limit $last,9"; $res=mysql_query($sql,$conn);}while ($row=mysql_fetch_assoc($res)){ $data[]=$row;}$_SESSION['last'] += count($data);echo json_encode( $data )
Get 取得できない場合は、もう一度最初から取得してください
さて、取得できないので、結果セットが空の場合は、ページを更新してもセッションを破棄すると判断しました。データを取得します
結果セットが空の場合、セッションを破棄させますが、破棄されてしまいます。これは無限ループです
結果セットは空だと思うので、ページが更新されるまで結果は取得できません。それからもう一度数えます
解決方法
このコードの最終的な結果セット json は JS ファイルに返され、js がページの位置を決定します 新しいコンテンツを常に読み込み、セッションを破棄しても、すぐにデータの取得を再開しますロードされているので!
これは頭が痛いです!
具体的に何がしたいのですか?
最新の80個のデータを少しずつ取得したいのですが、ページを更新して再度データを取得してしまうのがこのウォーターフォールフローです。
さて、このウォーターフォールフローの仕組みは、静的ページがjsを呼び出し、jsがページの現在位置を下から何ピクセル後に取得するというものですが、このphpコードでは問題ありません。 jsを取得する際にjsonが空であるかどうかを判断する必要がありますが空の場合は取得されないのでしょうか?
これで、js はスクロールされている限りコンテンツを取得し続けます。php の結果セットが空の場合、一度取得した後はデータが保持されます。
取得後、セッションからログアウトするか、$_SESSION を空に設定します
もちろん、JS 側でも返すデータがあるかどうかを確認する必要があります。ない場合は、それ以上のリクエストは送信されません
取得後、ログを記録します。セッションを終了するか、$_SESSION を空に設定します
もちろん、JS 側でもデータが返されるかどうかを確認する必要があります。そうでない場合は、リクエストは送信されません。ありがとうございます。 !

PHPタイプは、コードの品質と読みやすさを向上させるためのプロンプトがあります。 1)スカラータイプのヒント:php7.0であるため、基本データ型は、int、floatなどの関数パラメーターで指定できます。 3)ユニオンタイプのプロンプト:PHP8.0であるため、関数パラメーターまたは戻り値で複数のタイプを指定することができます。 4)Nullable Typeプロンプト:null値を含めることができ、null値を返す可能性のある機能を処理できます。

PHPでは、クローンキーワードを使用してオブジェクトのコピーを作成し、\ _ \ _クローンマジックメソッドを使用してクローン動作をカスタマイズします。 1.クローンキーワードを使用して浅いコピーを作成し、オブジェクトのプロパティをクローン化しますが、オブジェクトのプロパティはクローニングしません。 2。\ _ \ _クローン法は、浅いコピーの問題を避けるために、ネストされたオブジェクトを深くコピーできます。 3.クローニングにおける円形の参照とパフォーマンスの問題を避けるために注意し、クローニング操作を最適化して効率を向上させます。

PHPはWeb開発およびコンテンツ管理システムに適しており、Pythonはデータサイエンス、機械学習、自動化スクリプトに適しています。 1.PHPは、高速でスケーラブルなWebサイトとアプリケーションの構築においてうまく機能し、WordPressなどのCMSで一般的に使用されます。 2。Pythonは、NumpyやTensorflowなどの豊富なライブラリを使用して、データサイエンスと機械学習の分野で驚くほどパフォーマンスを発揮しています。

HTTPキャッシュヘッダーの主要なプレーヤーには、キャッシュコントロール、ETAG、およびラスト修飾が含まれます。 1.Cache-Controlは、キャッシュポリシーを制御するために使用されます。例:キャッシュコントロール:Max-Age = 3600、public。 2。ETAGは、一意の識別子を介してリソースの変更を検証します。例:ETAG: "686897696A7C876B7E"。 3. Last-Modifiedは、リソースの最後の変更時間を示しています。

PHPでは、Password_hashとpassword_verify関数を使用して安全なパスワードハッシュを実装する必要があり、MD5またはSHA1を使用しないでください。 1)password_hashセキュリティを強化するために、塩値を含むハッシュを生成します。 2)password_verifyハッシュ値を比較して、パスワードを確認し、セキュリティを確保します。 3)MD5とSHA1は脆弱であり、塩の値が不足しており、最新のパスワードセキュリティには適していません。

PHPは、動的なWeb開発およびサーバー側のアプリケーションに使用されるサーバー側のスクリプト言語です。 1.PHPは、編集を必要とせず、迅速な発展に適した解釈言語です。 2。PHPコードはHTMLに組み込まれているため、Webページの開発が簡単になりました。 3。PHPプロセスサーバー側のロジック、HTML出力を生成し、ユーザーの相互作用とデータ処理をサポートします。 4。PHPは、データベースと対話し、プロセスフォームの送信、サーバー側のタスクを実行できます。

PHPは過去数十年にわたってネットワークを形成しており、Web開発において重要な役割を果たし続けます。 1)PHPは1994年に発信され、MySQLとのシームレスな統合により、開発者にとって最初の選択肢となっています。 2)コア関数には、動的なコンテンツの生成とデータベースとの統合が含まれ、ウェブサイトをリアルタイムで更新し、パーソナライズされた方法で表示できるようにします。 3)PHPの幅広いアプリケーションとエコシステムは、長期的な影響を促進していますが、バージョンの更新とセキュリティの課題にも直面しています。 4)PHP7のリリースなど、近年のパフォーマンスの改善により、現代の言語と競合できるようになりました。 5)将来的には、PHPはコンテナ化やマイクロサービスなどの新しい課題に対処する必要がありますが、その柔軟性とアクティブなコミュニティにより適応性があります。

PHPの中心的な利点には、学習の容易さ、強力なWeb開発サポート、豊富なライブラリとフレームワーク、高性能とスケーラビリティ、クロスプラットフォームの互換性、費用対効果が含まれます。 1)初心者に適した学習と使用が簡単。 2)Webサーバーとの適切な統合および複数のデータベースをサポートします。 3)Laravelなどの強力なフレームワークを持っています。 4)最適化を通じて高性能を達成できます。 5)複数のオペレーティングシステムをサポートします。 6)開発コストを削減するためのオープンソース。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

WebStorm Mac版
便利なJavaScript開発ツール
