質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Q&A

解決済

2回答

4424閲覧

SELECT count(*) FROM XXX の件数と id が合わない

退会済みユーザー

退会済みユーザー

総合スコア0

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

0グッド

2クリップ

投稿2016/07/03 13:48

MySQLでSELECT count(*) FROM XXX;で件数を確認しているのですが、AUTO_INCREMENTで振ったidと数字がかけ離れてしまっており、困っています。

対象の table への操作は INSERT と UPDATE のみで、DELETE は行っておりません。また、id が1から始まっていることも確認しています。

どうも根本的に何かを勘違いしている気がするのですが、上記状況に関してご説明いただける方はいますか?

よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Mr_Roboto

2016/07/03 14:16

count(*)の数と、max(id)の数が違うということですか?
退会済みユーザー

退会済みユーザー

2016/07/03 14:29

ご迷惑をお掛けしました。
guest

回答2

0

ベストアンサー

対象の table への操作は INSERT と UPDATE のみで、DELETE は行っておりません。また、id が1から始まっていることも確認しています。

外しているかもしれませんが、可能性の一つとして。
データ操作がアプリケーションから行われている場合、(システムエラー等)エラー発生時のロールバックで欠番が発生していることが考えられませんでしょうか?

参考URL
https://dev.mysql.com/doc/refman/5.6/ja/innodb-auto-increment-traditional.html

カウンタを使用して数値が生成されたトランザクションをロールバックすると、AUTO_INCREMENT カラムに割り当てられた一連の値でギャップが見つかることがあります。

投稿2016/07/03 14:29

takyafumin

総合スコア2335

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/01/07 23:35

takyafumin さんの記述の意味がやっと少し理解できるレベルになりました。 INSERT ... ON DUPLICATE KEY UPDATE の使用で、AUTO_INCREMENT カラムに飛び番が発生しておりました。 今更ですが、ありがとうございました。
takyafumin

2017/01/08 01:03

状況の追記ありがとうございます。 原因解明まで進んだようで良かったです。 時間が経ってからでもこのように結果をコメントいただけると、回答者としてのモチベーションも上がり嬉しく思います。また、事例を検索して利用する方にも大変参考になる情報になるかと思います。
退会済みユーザー

退会済みユーザー

2017/01/08 01:19

正直、完全に理解できてるわけではないので、「こちらの回答が関係あったんだな」ってぐらいでしか評価できてないのが申し訳ないのですが、改めてコメントありがとうございます。 当時の理解としては、 「システム的なエラーの入る余地もない、当然ロールバックもないから事象と関係ないな!」って判断でした^^;理解不足であったため、コメントもできません。 今、リンク先見ると、かなり関連深いことが書かれていますね。 大変失礼しました。
guest

0

すみません。まだ途中ですが、自己解決です。
id を1づつ増やして、確認したところ、欠落している箇所がありました。

欠落した理由は不明なのですが、お騒がせしてすみません。

投稿2016/07/03 14:28

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/01/07 23:33

今更ですが、原因がわかりました。 INSERT ... ON DUPLICATE KEY UPDATE を使用していたのですが、それが悪さをしていたようです。 http://ftp.nchu.edu.tw/MySQL/doc/refman/5.1-olh/ja/innodb-auto-increment-configurable.html 結果として、当時の私では結び付けられなかったのですが、takyafumin さんの指摘の一部が正しかったようです。 takyafumin さん今更ながら気が付きました。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問