javascript - mysql update 的奇葩问题
update table_xxx set a=a+1 where documentid=123
如果数据库中为10 那么 执行后就是11
但是最后结果总是12 ,我都郁闷了一天了,怎么办。程序没有任何问题,我用mysql类,和原生的sql都试过了,都这这个问题,以前开发的时候也没有遇到,开发一年遇到这样的问题有解决不了,感觉就是一饭桶,求大神指教
数据库结构:
<code>CREATE TABLE comment_top_foot ( id int(10) NOT NULL AUTO_INCREMENT, documentid int(10) NOT NULL, commentid int(10) NOT NULL, topnum int(10) NOT NULL DEFAULT '0' COMMENT '对评论顶的数量', footnum int(10) NOT NULL DEFAULT '0' COMMENT '对评论踩的数量', PRIMARY KEY (id) ) ENGINE=MyISAM AUTO_INCREMENT=1500 DEFAULT CHARSET=latin1 </code>
刚才我在linux下运行脚本了,数据库中是加一的没错,但是我在浏览器访问这个脚本后数据库值加2 的,这是神马原因!
找到原因了,在同事那里用浏览器是正常的,我换成火狐或者ie也是正常的,现在用的是谷歌的,出问题了,唯一纳闷的是为什么谷歌浏览器会出问题。郁闷。。。
回复内容:
update table_xxx set a=a+1 where documentid=123
如果数据库中为10 那么 执行后就是11
但是最后结果总是12 ,我都郁闷了一天了,怎么办。程序没有任何问题,我用mysql类,和原生的sql都试过了,都这这个问题,以前开发的时候也没有遇到,开发一年遇到这样的问题有解决不了,感觉就是一饭桶,求大神指教
数据库结构:
<code>CREATE TABLE comment_top_foot ( id int(10) NOT NULL AUTO_INCREMENT, documentid int(10) NOT NULL, commentid int(10) NOT NULL, topnum int(10) NOT NULL DEFAULT '0' COMMENT '对评论顶的数量', footnum int(10) NOT NULL DEFAULT '0' COMMENT '对评论踩的数量', PRIMARY KEY (id) ) ENGINE=MyISAM AUTO_INCREMENT=1500 DEFAULT CHARSET=latin1 </code>
刚才我在linux下运行脚本了,数据库中是加一的没错,但是我在浏览器访问这个脚本后数据库值加2 的,这是神马原因!
找到原因了,在同事那里用浏览器是正常的,我换成火狐或者ie也是正常的,现在用的是谷歌的,出问题了,唯一纳闷的是为什么谷歌浏览器会出问题。郁闷。。。
考虑下,你防重复提交逻辑做了没有?
抓一下http请求,看看发了几个请求过去了。
http://stackoverflow.com/questions/19264616/mysql-update-query-is-executing-twice-in-chrome-but-once-in-mozilla
https://codebuildplay.wordpress.com/2014/03/06/chrome-loads-page-twice-sitecore-dms-gets-faulty-usage-data/
能把代码贴上来么, 我在本地的测试正确的, 我是在mysql 命令行 里面敲的
<code>update ask_posts set state=state+1 where id=10; </code>
得到的结果:
你应该把PHP代码贴出来,问题很可能是在那

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

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

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

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

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック











session_start()iscrucialinphpformangingusersions.1)itInitiateSanewsessionifnoneExists、2)resumesanexistingsession、および3)SetSessionCookieforcontinuityAcrossRequests、ApplicationslicationSliviseSlikeUserauthicationAnticatent。

MySQLでは、AlterTabletable_nameaddcolumnnew_columnvarchar(255)afterexisting_columnを使用してフィールドを追加し、andtabletable_namedopcolumncolumn_to_dropを使用してフィールドを削除します。フィールドを追加するときは、クエリのパフォーマンスとデータ構造を最適化する場所を指定する必要があります。フィールドを削除する前に、操作が不可逆的であることを確認する必要があります。オンラインDDL、バックアップデータ、テスト環境、および低負荷期間を使用したテーブル構造の変更は、パフォーマンスの最適化とベストプラクティスです。

MySQL関数は、データ処理と計算に使用できます。 1.基本的な使用には、文字列処理、日付計算、数学操作が含まれます。 2。高度な使用法には、複数の関数を組み合わせて複雑な操作を実装することが含まれます。 3.パフォーマンスの最適化では、Where句での機能の使用を回避し、GroupByおよび一時テーブルを使用する必要があります。

安全かつ徹底的にMySQLをアンインストールし、すべての残留ファイルをクリーンにするには、次の手順に従ってください。1。MySQLサービスを停止します。 2。MySQLパッケージをアンインストールします。 3.構成ファイルとデータディレクトリのクリーン。 4.アンインストールが徹底していることを確認します。

Composerは、PHPの依存関係管理ツールであり、Composer.jsonファイルを介してプロジェクトの依存関係を管理しています。 1)依存関係情報を取得するためのComposer.jsonを解析する。 2)依存関係を解析して、依存性ツリーを形成します。 3)PackagistからVendorディレクトリへの依存関係をダウンロードしてインストールします。 4)Composer.Lockファイルを生成して、依存関係バージョンをロックして、チームの一貫性とプロジェクトの保守性を確保します。

MySQLでデータを挿入するための効率的な方法には、次のものが含まれます。1。insertInto ...値構文、2。LoadDatainFileコマンドの使用、3。トランザクション処理の使用、4。バッチサイズの調整、5。Insurtignoreまたは挿入の使用...

MySQLがさまざまなプロジェクトで広く使用されている理由には、次のものがあります。1。複数のストレージエンジンをサポートする高性能とスケーラビリティ。 2。使いやすく、メンテナンス、シンプルな構成とリッチツール。 3。豊富なエコシステム、多数のコミュニティとサードパーティのツールサポートを魅了します。 4。複数のオペレーティングシステムに適したクロスプラットフォームサポート。

MySQLで文字セットと照合を構成する方法は次のとおりです。1。サーバーレベルでの文字セットとコレクションの設定:setNames'utf8 '; setCharacterSetutf8; setCollation_connection = 'utf8_general_ci'; 2。特定の文字セットと照合を使用するデータベースを作成します:createdatabaseexample_dbcharactersetutf8collateutf8_general_ci; 3.テーブルを作成するときに文字セットとコレクションを指定:createTableExample_table(idint
