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

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

ただいまの
回答率

89.99%

C#で作ったアプリによってMDBファイルにINSERTしたレコードのIDフィールドの値が増大した

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 540

kbys32

score 50

お世話になります。

表題の通り、C#で作ったアプリでMDBファイルへ、レコードをINSERTしたところ、
MDBファイルを作った時から存在するIDフィールドが1ずつ加算されず、6610番のレコードの次が、13136番になってしまいました。
IDフィールドは、6610番まで、および13136番以降は1ずつ加算されるのですが、なぜかその番号だけ奇怪な現象がおき、原因も対策も分からず、困っています。
あくまで、IDフィールドはプログラム等で、いじっていません。
レコードをINSERTしたり、MDBへの接続準備をしたりする手続きは、以下の通りです。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.Common;
using System.Data;
using System.Data.OleDb;
using System.IO;

    class MdbAccess
    {
        private string error="";
        private OleDbConnection conn;   //データベースへの接続部

        //データベースに接続
        public MdbAccess()
        {
            conn = new OleDbConnection();
            string path="filename";

            //データベースに接続
            conn.ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" +path + ".mdb; Persist Security Info = False" ;

            if (IntPtr.Size == 8)
            {
                //64bitでは「Microsoft.Jet.OLEDB.4.0」は使えない
                conn.ConnectionString = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" +path + ".mdb; Persist Security Info = False" ;

            }

            //開く
            conn.Open(); 



        }

        public string geterror() { return error; }


        //SQL実行
        public void RunSQL(string sql)
        {

            DbCommand command = conn.CreateCommand();


            command.CommandText = sql;//コマンドを登録

            command.ExecuteNonQuery();//コマンドを実行
        }

    }


どうすれば、IDフィールドの値の増大を阻止できますか。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+4

その ID 列はオートナンバーではないのですか? であれば、行を削除したり、INSERT に失敗してロークバックされたような場合、ID 値は飛んでしまいます。

6610 番から 13136 番までの間でそういうことがあったのかは分かりませんが・・・

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/12/22 14:48

    ありがとうございます。
    今、ロークバックについて調べています。
    また、アプリの利用者にメールで、そのエラーが起きた時の状況を問い合わせていますが、返事がありません。

    返事が来るまでに、できることをやっておきたいのですが、INSERTが失敗する場面というのは、どのようような状況と対策がありますか?

    少なくとも、行を削除したという話は聞かないので、INSERTの失敗だとは思います。

    キャンセル

  • 2018/12/22 17:35 編集

    トランザクション コミット ロールバック などをキーワードにググってもらった方が、私がここで説明するより、図解を含めた解説など分かりやすい記事が見つかると思います。

    キャンセル

  • 2018/12/22 19:07

    ありがとうございます。やってみます。

    キャンセル

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

  • ただいまの回答率 89.99%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる
  • トップ
  • C#に関する質問
  • C#で作ったアプリによってMDBファイルにINSERTしたレコードのIDフィールドの値が増大した