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

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

ただいまの
回答率

87.49%

SQL Server 2014 Express のmdf ファイルに書き込みできない

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 2,562

score 45

こんにちは↓
https://teratail.com/questions/46898
↑ここを元に書き換えをしてみました。
SQLserverからテーブルをローカルのmdfファイルに書き込みたくて

Visual Studio 2015で C#(WPF) 
mdfファイル(SQL Server 2014 Express) にinsert文で書き込みしようとすると

private void 更新()
        {

            string MDF接続文字 = "Data Source=(LocalDB)\\MSSQLLocalDB;AttachDbFilename=C:\\mylocal.mdf;Integrated Security=True";
            string SQL接続文字 = "Data Source='IPアドレス';Initial Catalog='サーバー名';Persist Security Info=True;User ID='アカウント';Password='パスワード'";



            SqlDataReader SQLreader;
            using (SqlConnection MDFcn = new SqlConnection(MDF接続文字), SQLcn = new SqlConnection(SQL接続文字))
            {
                try{SQLcn.Open();}catch(System.Exception ex) {System.Console.WriteLine(ex.Message);return;}
                MDFcn.Open();
                using (SqlCommand SQLcmd = new SqlCommand("SELECT * FROM テーブル", SQLcn))
                {
                    using (SQLreader = SQLcmd.ExecuteReader())
                    {
                        if(SQLreader.HasRows)
                        {
                            using (SqlCommand MDFcmd = new SqlCommand("DELETE FROM テーブル", MDFcn))
                            {
                                int num = MDFcmd.ExecuteNonQuery();
                                Console.WriteLine(num);
                                System.Diagnostics.Debug.WriteLine(num);

                                int mycolum = 0;
                                List<string> listFieldName = new List<string>();
                                foreach (DataRow myRow in SQLreader.GetSchemaTable().Rows)
                                {
                                    //フィールド名のリスト化
                                    string FieldName = (string)myRow["ColumnName"].ToString();
                                    listFieldName.Add(FieldName);
                                    設定表.Columns[mycolum++].Header = FieldName;
                                    //パラメーターの生成
                                    SqlDbType myType = (SqlDbType)myRow["ProviderType"];
                                    MDFcmd.Parameters.Add(FieldName, myType);
                                }
                                Array arrayFields = listFieldName.ToArray();
                                string myFieldNames = String.Join(", ", listFieldName.ToArray());
                                string myFieldValue = String.Join(", @", listFieldName.ToArray());
                                MDFcmd.CommandText = "INSERT INTO テーブル(" + myFieldNames + ") VALUES(@" + myFieldValue + ")";

                                System.Diagnostics.Debug.WriteLine(SQLreader.FieldCount);


                                while(SQLreader.Read())
                                {
                                    //全フィールドの値をパラメーターにセットする
                                    for (int myindex = 0; myindex < listFieldName.Count; ++myindex)
                                    {
                                        MDFcmd.Parameters[myindex].Value = SQLreader[myindex];

                                    }
                                    //INSERT文を発行する
                                    MDFcmd.ExecuteNonQuery();//←ここでエラーが出る。
                                    System.Diagnostics.Debug.WriteLine(MDFcmd.CommandText);
                                }
                            }
                        }
                    }
                }
                SQLcn.Close();
                MDFcn.Close();
            }
        }

エラー内容
追加情報:Failed to update database "C:\MYLOCAL.MDF" because the database is read-only.

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

check解決した方法

0

自己解決?しました。
プロジェクトファイルからコピーして別の場所に保存すると読取専用になってしまうようでした。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

0

英文ですが、
Failed to update database because the database is read-only.

コードは </> で囲んでください。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/10/27 15:00

    ありがとうございます。直しました。

    キャンセル

  • 2016/10/27 15:32

    Failed to update database because the database is read-only.
    の内容は試しましたか?
    英語が苦手なら翻訳サイト(精度は悪いですが)を利用してください。
    https://translate.google.com/

    キャンセル

  • 2016/10/27 16:04

    読み取り専用なのはわかるんですが…
    visualstudio 2015 でオブジェクトエクスプローラーから
    読み取り専用になっているのも確認しましたが…
    変えられるってサイトで書いてありましたが、右クリックしてプロパティを触ろうとしても変更できませんでした。

    キャンセル

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

  • ただいまの回答率 87.49%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る