検索
ホームページバックエンド開発PHPチュートリアルMySQL は、update、delete、insert ステートメントが正常に実行されたことをどのように確認しますか?

タイトルにあるように、現在は mysql_affected_rows() によって判断しています。これは、ほぼすべての update、delete、insert ステートメントの後に
if(mysql_affected_rows()!=1) という文が続く必要があることを意味します
{
エラー報告
}

もっと簡単な方法は何ですか?


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

mysql_affected_rows は、実行が成功したかどうかを確認するために使用されるのではなく、関連する SQL 命令が操作されたレコードの数を観察するために使用されます

直接
if(执行sql语句){.....}else{......}

l_affected_rows 対象外実行が成功したかどうかの検査

は、関連する SQL 命令が実行されたレコードの数を観察するために使用されます

が私の質問です。私は、insert、delete、update ステートメントが少なくとも 1 つの行に影響を与えたことを確認したいだけです
影響を受けた行の数を確認するには、mysql_affected_rows() を実行する必要があります。

影響を受ける行が何行(0 行も含む)であっても、エラーではありません

影響を受ける行が何行(0 行を含む)であっても、エラーではありません

もちろん、これは知っています。 。 。

タイトルにあるように、常に mysql_affected_rows() によって判断されます。これは、ほぼすべての update、delete、insert 文の後に

if(mysql_affected_rows()!=1)
{
エラー レポートが続く必要があることを意味します。
}

聞いてください 何か簡単な方法はありますか?


補足すると、update、delete、insert文が少なくとも1行に影響を与えていると判断したいのですが、多くの場合そのような判断ロジックが必要なようです
理由は、update、delete、insertが0行であっても影響があるからです。行を更新すると、トランザクションはロールバックされないため、この問題が発生します
更新に条件を満たすレコードがない場合、変更された値が元の値と同じである場合、変更されません。実際には変更は行われません。

削除 条件を満たすレコードが存在しない場合は削除されません。条件を満たすレコードが複数ある場合は、当然まとめて削除されます。
挿入は 100 件のレコードであっても 1 つのみに影響します。省略された挿入ステートメントを使用して挿入されます

これがトランザクションとどのような関係があるのか​​わかりません

update 条件を満たすレコードがない場合、変更された値が同じ場合は変更されません。元の値のままでは実際には変更されません

delete 条件を満たすレコードが無い場合は削除されません 条件を満たすレコードが複数ある場合は当然レコードも削除されます
insert のみに影響します。短縮された挿入ステートメントを使用して 100 個が挿入されたとしても 1 つ

これがトランザクションと何の関係があるのか​​わかりません


よく考えてみると、あなたの言ったことは理にかなっています。
私の質問の例を挙げてみましょう:
たとえば、ユーザーが仮想アイテムを購入するために仮想通貨を使用したい場合、更新後 ... setmoney= ... ここで user_id =... ステートメントが実行されると、 1 行が正常に更新されたことを確認するには、mysql_affected_rows() を使用する必要がありますか?実際にお金のフィールドが更新されていないのではないかと心配なので、ユーザーに仮想アイテムを追加する次の作業を実行します
以前に更新のために select Money from ... を実行した場合、確実であることが保証されますか?

update 条件を満たすレコードがない場合、変更されません。 変更された値が元の値と同じ場合、実際には変更されません。
削除 条件を満たすレコードがない場合。複数のレコードがある場合、条件を満たすレコードは自然にまとめて削除されます
短縮された挿入ステートメントを使用して 100 件のレコードが挿入された場合でも、挿入は 1 つのレコードにのみ影響します

これが何なのかわかりません取引に関係があります


よく考えてみると、あなたの言ったことは理にかなっています。
私の質問の例を挙げてみましょう:
たとえば、ユーザーが仮想アイテムを購入するために仮想通貨を使用したい場合、更新後 ... setmoney= ... ここで user_id =... ステートメントが実行されると、 1 行が正常に更新されたことを確認するには、mysql_affected_rows() を使用する必要がありますか?実際にお金のフィールドが更新されていないのではないかと心配なので、ユーザーに仮想アイテムを追加する次の作業を実行します
以前に更新のために select Money from ... を実行した場合、確実であることが保証されますか?
Direct if (更新操作....) {購入成功...}else {購入失敗....} は問題ありません。更新操作は失敗し、false を返します
$result = mysql_query("update ……")if ($result !== false){    echo "exec success";}else{    echo "exec error:".mysql_error():}



update 没有符合条件的记录,就不会修改,如果被修改的值和原值一样,则修改不会真正发生
delete 没有符合条件的记录,就不会删除,如果有多条符合条件的记录,自然也就一并删除了
insert 只会影响一条,哪怕是用缩略写法的 insert 语句插入了 100 条

看不出这与事务有什么关系



想了一下,你说的有道理。
我把我的疑问举个例子:
比如用户要用虚拟货币购买虚拟物品,在update ... set money= ... where user_id=... 这条语句执行后,需不需要mysql_affected_rows()来验证成功update了1行呢?我担心没真正update到money字段,然后就执行了下面给该用户添加虚拟物品的业务
如果在之前执行了select money from ... for update,就能保证万无一失吗?
直接if (update操作....){购买成功...}else{购买失败....}不就好了,update操作失败返回的是false

好的我决定试一下,看起来比mysql_affected_rows简洁,不知道效果上有没有什么细微差别

$result = mysql_query("update ……")if ($result !== false){    echo "exec success";}else{    echo "exec error:".mysql_error():}



同上,谢谢,准备试一下效果

如果你不放心 update ... set money=money-1 会真实执行的话
那么你是否需要再 select 一下,确认 money 减少了 1,而不是减少了 100 呢?

$result = mysql_query("update ……")
只有在 sql 指令是错误的情况下,才会返回 false 
所以并不需要去试

如果你不放心 update ... set money=money-1 会真实执行的话
那么你是否需要再 select 一下,确认 money 减少了 1,而不是减少了 100 呢?

$result = mysql_query("update ……")
只有在 sql 指令是错误的情况下,才会返回 false 
所以并不需要去试

如果你不放心 update ... set money=money-1 会真实执行的话
那么你是否需要再 select 一下,确认 money 减少了 1,而不是减少了 100 呢?

$result = mysql_query("update ……")
只有在 sql 指令是错误的情况下,才会返回 false 
所以并不需要去试


好的,感觉你说的听起来比较靠谱,谢谢。
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
アクション中のPHP:実際の例とアプリケーションアクション中のPHP:実際の例とアプリケーションApr 14, 2025 am 12:19 AM

PHPは、電子商取引、コンテンツ管理システム、API開発で広く使用されています。 1)eコマース:ショッピングカート機能と支払い処理に使用。 2)コンテンツ管理システム:動的コンテンツの生成とユーザー管理に使用されます。 3)API開発:RESTFUL API開発とAPIセキュリティに使用されます。パフォーマンスの最適化とベストプラクティスを通じて、PHPアプリケーションの効率と保守性が向上します。

PHP:インタラクティブなWebコンテンツを簡単に作成しますPHP:インタラクティブなWebコンテンツを簡単に作成しますApr 14, 2025 am 12:15 AM

PHPにより、インタラクティブなWebコンテンツを簡単に作成できます。 1)HTMLを埋め込んでコンテンツを動的に生成し、ユーザー入力またはデータベースデータに基づいてリアルタイムで表示します。 2)プロセスフォームの提出と動的出力を生成して、XSSを防ぐためにHTMLSPECIALCHARSを使用していることを確認します。 3)MySQLを使用してユーザー登録システムを作成し、Password_HashおよびPreprocessingステートメントを使用してセキュリティを強化します。これらの手法を習得すると、Web開発の効率が向上します。

PHPとPython:2つの一般的なプログラミング言語を比較しますPHPとPython:2つの一般的なプログラミング言語を比較しますApr 14, 2025 am 12:13 AM

PHPとPythonにはそれぞれ独自の利点があり、プロジェクトの要件に従って選択します。 1.PHPは、特にWebサイトの迅速な開発とメンテナンスに適しています。 2。Pythonは、データサイエンス、機械学習、人工知能に適しており、簡潔な構文を備えており、初心者に適しています。

PHPの永続的な関連性:それはまだ生きていますか?PHPの永続的な関連性:それはまだ生きていますか?Apr 14, 2025 am 12:12 AM

PHPは依然として動的であり、現代のプログラミングの分野で重要な位置を占めています。 1)PHPのシンプルさと強力なコミュニティサポートにより、Web開発で広く使用されています。 2)その柔軟性と安定性により、Webフォーム、データベース操作、ファイル処理の処理において顕著になります。 3)PHPは、初心者や経験豊富な開発者に適した、常に進化し、最適化しています。

PHPの現在のステータス:Web開発動向を見てくださいPHPの現在のステータス:Web開発動向を見てくださいApr 13, 2025 am 12:20 AM

PHPは、現代のWeb開発、特にコンテンツ管理とeコマースプラットフォームで依然として重要です。 1)PHPには、LaravelやSymfonyなどの豊富なエコシステムと強力なフレームワークサポートがあります。 2)パフォーマンスの最適化は、Opcacheとnginxを通じて達成できます。 3)PHP8.0は、パフォーマンスを改善するためにJITコンパイラを導入します。 4)クラウドネイティブアプリケーションは、DockerおよびKubernetesを介して展開され、柔軟性とスケーラビリティを向上させます。

PHP対その他の言語:比較PHP対その他の言語:比較Apr 13, 2025 am 12:19 AM

PHPは、特に迅速な開発や動的なコンテンツの処理に適していますが、データサイエンスとエンタープライズレベルのアプリケーションには良くありません。 Pythonと比較して、PHPはWeb開発においてより多くの利点がありますが、データサイエンスの分野ではPythonほど良くありません。 Javaと比較して、PHPはエンタープライズレベルのアプリケーションでより悪化しますが、Web開発により柔軟性があります。 JavaScriptと比較して、PHPはバックエンド開発により簡潔ですが、フロントエンド開発のJavaScriptほど良くありません。

PHP対Python:コア機能と機能PHP対Python:コア機能と機能Apr 13, 2025 am 12:16 AM

PHPとPythonにはそれぞれ独自の利点があり、さまざまなシナリオに適しています。 1.PHPはWeb開発に適しており、組み込みのWebサーバーとRich Functionライブラリを提供します。 2。Pythonは、簡潔な構文と強力な標準ライブラリを備えたデータサイエンスと機械学習に適しています。選択するときは、プロジェクトの要件に基づいて決定する必要があります。

PHP:Web開発の重要な言語PHP:Web開発の重要な言語Apr 13, 2025 am 12:08 AM

PHPは、サーバー側で広く使用されているスクリプト言語で、特にWeb開発に適しています。 1.PHPは、HTMLを埋め込み、HTTP要求と応答を処理し、さまざまなデータベースをサポートできます。 2.PHPは、ダイナミックWebコンテンツ、プロセスフォームデータ、アクセスデータベースなどを生成するために使用され、強力なコミュニティサポートとオープンソースリソースを備えています。 3。PHPは解釈された言語であり、実行プロセスには語彙分析、文法分析、編集、実行が含まれます。 4.PHPは、ユーザー登録システムなどの高度なアプリケーションについてMySQLと組み合わせることができます。 5。PHPをデバッグするときは、error_reporting()やvar_dump()などの関数を使用できます。 6. PHPコードを最適化して、キャッシュメカニズムを使用し、データベースクエリを最適化し、組み込み関数を使用します。 7

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ヘンタイを無料で生成します。

ホットツール

PhpStorm Mac バージョン

PhpStorm Mac バージョン

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

SublimeText3 Mac版

SublimeText3 Mac版

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

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター