検索
ホームページバックエンド開発PHPチュートリアルjavascript - 用户修改一个列表型的数据,后台和数据库互动时应该怎么操作好?

比如每个用户有一个自己的收藏列表,用户可以增加和删除列表中的任一项。

那么用HTTP请求和数据库互动时,以下哪种是最科学的呢?
1,每次增删都发起一次HTTP请求,在数据库上作相应操作(这个HTTP请求太多我自己觉得不科学)
2,把数据库上的列表数据下载下来呈现给用户后,只在前端的数据模型中增删,等到用户可能要关闭页面时用一次HTTP请求来同步,使数据库上的数据更新。不过我主要想问的是这里又有两种具体的互动方法,请大家赐教:
2a,在前端数据模型操作时,记录下哪些被增加了哪些被删除了。在更新数据库做Insert into... where value in和Delete ... where value in 这两次操作
2b,前端只记录数据模型。在更新数据库时直接truncate原来的表,把新的表数据插入。
请问2a和2b哪种比较好?
另外,第2步中同步的时机一般应该是什么时候呢?是用interval来定时同步呢?还是在用户进行一个特定的操作后来同步?谢谢。

-------1218更新
不好意思,上面忘记说了,我指的是用angularJS这种情况下,可以用数据模型来暂存数据的

回复内容:

比如每个用户有一个自己的收藏列表,用户可以增加和删除列表中的任一项。

那么用HTTP请求和数据库互动时,以下哪种是最科学的呢?
1,每次增删都发起一次HTTP请求,在数据库上作相应操作(这个HTTP请求太多我自己觉得不科学)
2,把数据库上的列表数据下载下来呈现给用户后,只在前端的数据模型中增删,等到用户可能要关闭页面时用一次HTTP请求来同步,使数据库上的数据更新。不过我主要想问的是这里又有两种具体的互动方法,请大家赐教:
2a,在前端数据模型操作时,记录下哪些被增加了哪些被删除了。在更新数据库做Insert into... where value in和Delete ... where value in 这两次操作
2b,前端只记录数据模型。在更新数据库时直接truncate原来的表,把新的表数据插入。
请问2a和2b哪种比较好?
另外,第2步中同步的时机一般应该是什么时候呢?是用interval来定时同步呢?还是在用户进行一个特定的操作后来同步?谢谢。

-------1218更新
不好意思,上面忘记说了,我指的是用angularJS这种情况下,可以用数据模型来暂存数据的

1.你为什么认为1是不科学的呢?天知道客户端哪边会发生什么事情~~当用户添加了N个收藏,猫猫过来把电源搞掉了-关机了,这个咋整哦~~~
2.用户希望它的每一步操作都是有效而真实的~~
3.删除动作,不要DELETE,UPDATE原纪录,做逻辑删除
4.truncate表这么暴力的招都用上啦,不要啊~~~~

只能每次发请求这是http

肯定要每次发送请求啊,你在前端怎么保存数据?如果不将用户的操作存入数据库,当用户不小心刷新页面或者关闭页面,他的操作在前端根本没有办法记录下来。

这种就看你要怎么设计了,如果你列表下面有个提交或者保存按钮,用户就明白N种操作完成必须提交或保存才能生效;如果你没有这种提示性信号,只是在每个列表后有个删除,然后有个随意增加的,用户理解成操作即保存,那就不能缓存处理了呗,只能实时性操作数据库

truncate这个有点不太科学,除非每个用户都有一个自已的收藏表
可以找找 window.onbeforeunload 这个事件 在事件中先判断用户收藏的数据是否有改动,有则http请求处理

最近我也在烦这个http请求次数的问题,看了你的描述之后,突然有个想法。。。但不知道可行不可行。。。
首先是获取数据的时候将数据存入一个数据模型里,然后让页面从这个数据模型里面拿取数据。
当页面发生修改事件时,将修改后的数据存入数据模型,然后再从模型拿出修改页面
然后开个定时器,隔一定时间就判断数据模型里面的数据是否发生改动,是就发生请求,不是就不发送。
最后当用户离开该页面的时候最后再判断一次。。。
。。。
或许可以当第一个修改事件发生的时候开启定时器。。。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPの継続的な使用:その持久力の理由PHPの継続的な使用:その持久力の理由Apr 19, 2025 am 12:23 AM

まだ人気があるのは、使いやすさ、柔軟性、強力なエコシステムです。 1)使いやすさとシンプルな構文により、初心者にとって最初の選択肢になります。 2)Web開発、HTTP要求とデータベースとの優れた相互作用と密接に統合されています。 3)巨大なエコシステムは、豊富なツールとライブラリを提供します。 4)アクティブなコミュニティとオープンソースの性質は、それらを新しいニーズとテクノロジーの傾向に適応させます。

PHPおよびPython:類似点と相違点を調査しますPHPおよびPython:類似点と相違点を調査しますApr 19, 2025 am 12:21 AM

PHPとPythonはどちらも、Web開発、データ処理、自動化タスクで広く使用されている高レベルのプログラミング言語です。 1.PHPは、ダイナミックウェブサイトとコンテンツ管理システムの構築によく使用されますが、PythonはWebフレームワークとデータサイエンスの構築に使用されることがよくあります。 2.PHPはエコーを使用してコンテンツを出力し、Pythonは印刷を使用します。 3.両方ともオブジェクト指向プログラミングをサポートしますが、構文とキーワードは異なります。 4。PHPは弱いタイプの変換をサポートしますが、Pythonはより厳しくなります。 5. PHPパフォーマンスの最適化には、Opcacheおよび非同期プログラミングの使用が含まれますが、PythonはCprofileおよび非同期プログラミングを使用します。

PHPおよびPython:さまざまなパラダイムが説明されていますPHPおよびPython:さまざまなパラダイムが説明されていますApr 18, 2025 am 12:26 AM

PHPは主に手順プログラミングですが、オブジェクト指向プログラミング(OOP)もサポートしています。 Pythonは、OOP、機能、手続き上のプログラミングなど、さまざまなパラダイムをサポートしています。 PHPはWeb開発に適しており、Pythonはデータ分析や機械学習などのさまざまなアプリケーションに適しています。

PHPとPython:彼らの歴史を深く掘り下げますPHPとPython:彼らの歴史を深く掘り下げますApr 18, 2025 am 12:25 AM

PHPは1994年に発信され、Rasmuslerdorfによって開発されました。もともとはウェブサイトの訪問者を追跡するために使用され、サーバー側のスクリプト言語に徐々に進化し、Web開発で広く使用されていました。 Pythonは、1980年代後半にGuidovan Rossumによって開発され、1991年に最初にリリースされました。コードの読みやすさとシンプルさを強調し、科学的コンピューティング、データ分析、その他の分野に適しています。

PHPとPythonの選択:ガイドPHPとPythonの選択:ガイドApr 18, 2025 am 12:24 AM

PHPはWeb開発と迅速なプロトタイピングに適しており、Pythonはデータサイエンスと機械学習に適しています。 1.PHPは、単純な構文と迅速な開発に適した動的なWeb開発に使用されます。 2。Pythonには簡潔な構文があり、複数のフィールドに適しており、強力なライブラリエコシステムがあります。

PHPとフレームワーク:言語の近代化PHPとフレームワーク:言語の近代化Apr 18, 2025 am 12:14 AM

PHPは、多数のWebサイトとアプリケーションをサポートし、フレームワークを通じて開発ニーズに適応するため、近代化プロセスで依然として重要です。 1.PHP7はパフォーマンスを向上させ、新機能を紹介します。 2。Laravel、Symfony、Codeigniterなどの最新のフレームワークは、開発を簡素化し、コードの品質を向上させます。 3.パフォーマンスの最適化とベストプラクティスは、アプリケーションの効率をさらに改善します。

PHPの影響:Web開発などPHPの影響:Web開発などApr 18, 2025 am 12:10 AM

phphassiblasifly-impactedwebdevevermentandsbeyondit.1)itpowersmajorplatformslikewordpratsandexcelsindatabase interactions.2)php'sadaptableability allowsitale forlargeapplicationsusingframeworkslikelavel.3)

スカラータイプ、リターンタイプ、ユニオンタイプ、ヌル可能なタイプなど、PHPタイプのヒントはどのように機能しますか?スカラータイプ、リターンタイプ、ユニオンタイプ、ヌル可能なタイプなど、PHPタイプのヒントはどのように機能しますか?Apr 17, 2025 am 12:25 AM

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

See all articles

ホット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

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

SecLists

SecLists

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

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境