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

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

ただいまの
回答率

89.97%

VB.NETでSQLite 更新

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 2,538

otojiro

score 23

Visual Studio 2017 でVB+SQLiteで顧客管理などのアプリの為に勉強中で、何度も挫折してAccessに戻ってはまたVSに取り組んでみてはを繰り返しております。ACCESSではお金が取れるほどではありませんが、自己使用のアプリを作れる程度です。

今回は、ほんとに初歩的なことなのかもしれませんが、SQLiteの更新について質問させてください。

https://qiita.com/akabei/items/3e719d07bdddd6fe56b8
上記ページを参考にSQLiteに接続してみて、参考サイトの通りの動作はしております。

そこで「Button3」をフォームに配置して、DataGridViewに表示されたSQLiteデータベースの内容を書き換え(追加ではありません)てSQLiteに反映させることを試しております。

Imports System.Data.SQLite

Public Class Form1

    ''' <summary>
    ''' データベース作成ボタンクリック
    ''' </summary>
    Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
        Try
            Using con As New SQLiteConnection("Data Source=sample.db")
                con.Open()
                Using cmd As SQLiteCommand = con.CreateCommand()
                    cmd.CommandText = "CREATE TABLE Sample (ID INTEGER PRIMARY KEY, Name NVARCHAR(128), Age INTEGER)"
                    cmd.ExecuteNonQuery()
                    cmd.CommandText = "INSERT INTO Sample (Name, Age) VALUES('一郎', 10)"
                    cmd.ExecuteNonQuery()
                    cmd.CommandText = "INSERT INTO Sample (Name, Age) VALUES('二郎', 20)"
                    cmd.ExecuteNonQuery()
                    cmd.CommandText = "INSERT INTO Sample (Name, Age) VALUES('三郎', 30)"
                    cmd.ExecuteNonQuery()
                End Using
            End Using
            MessageBox.Show("Sampleデータベース作成成功", Me.Text, MessageBoxButtons.OK, MessageBoxIcon.Information)
        Catch ex As Exception
            MessageBox.Show("Sampleデータベース作成失敗" + Environment.NewLine + ex.Message, Me.Text, MessageBoxButtons.OK, MessageBoxIcon.Error)
        End Try
    End Sub

    ''' <summary>
    ''' 検索ボタンクリック
    ''' </summary>
    Private Sub Button2_Click(sender As Object, e As EventArgs) Handles Button2.Click
        Using con As New SQLiteConnection("Data Source=sample.db")
            Dim ds As New DataSet
            Dim da As New SQLiteDataAdapter("SELECT * FROM Sample", con)
            da.Fill(ds, "Sample")
            Me.DataGridView1.DataSource = ds.Tables("Sample")
        End Using
    End Sub

  Private Sub Button3_Click(sender As Object, e As EventArgs) Handles Button3.Click
        Using con As New SQLiteConnection("Data Source=sample.db")
            Dim ds As New DataSet
            Dim da As New SQLiteDataAdapter("SELECT * FROM Sample", con)

            da.Update(ds, "Sample")
        End Using
    End Sub
End Class

上記で実行すると、
System.InvalidOperationException:
Update で TableMapping['Sample'] 、または DataTable 'Sample' が見つかりませんでした。
Source=System.Data

のエラーが出ました。

今試しているのは変更ですが、追加、削除をごそっと丸ごとSqliteのテーブルに反映させるにはいろいろな方法があるのかもしれませんが、今参考にしている記事のサンプルの流れで行くにはどのような記述になるのでしょうか?

よろしくお願いいたします。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

0

更新するにも先にDataAdapterをFillしておかないと、DataAdapterにDataTableがない状態じゃないですか?
ソースのコピペミスかもしれませんが..

DataAdapter によるデータ ソースの更新をよく読んでみては

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/01/21 18:24

    回答ありがとうございます。
    たしかにFillしてなかったです。

    Private Sub Button3_Click(sender As Object, e As EventArgs) Handles Button3.Click
    Using con As New SQLiteConnection("Data Source=sample.db")
    Dim ds As New DataSet
    Dim da As New SQLiteDataAdapter("SELECT * FROM Sample", con)
    da.Fill(ds, "Sample")
    da.Update(ds, "Sample")
    End Using
    End Sub

    これでとりあえずはエラーが出なくなりました。
    ただ確認したところデータベースのデータは更新されていなかったので、教えていただきました参考サイトでもう少し勉強してみます。

    キャンセル

  • 2018/01/21 20:40

    > データは更新されていなかった
    UpdateCommandを書いていないからでは?
    UpdateCommandは自動生成されないときもあるので、きちんとUpdateCommandを書いてあげないといけないのでは?

    キャンセル

  • 2018/01/24 19:22

    ありがとうございます。
    お返事遅くなり申し訳ございません。
    無事に解決して、思うような動作になりました。
    ひとつずつ機能を増やしながらスキルアップしてい行きたいと思います。

    キャンセル

0

Visual Studio 2017でSQLiteを使ったWindowsフォームアプリ開発 の Form1.vb にある、CREATE TABLE文

 cmd.CommandText = "CREATE TABLE Sample (ID INTEGER PRIMARY KEY, Name NVARCHAR(128), Age INTEGER)"

は実行していますか?

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/01/20 13:21

    はい、そのCREATE文でテーブルを作成しました。

    キャンセル

  • 2018/01/20 16:14

    環境 Windows 7 Professional SP1 64bit, Visual Studio 2017 Community などは同じでしょうか?Button3_Click以外のコードも最初から載せた方が良いように思えます。提示されたURLのButton2_Click は正常に実行できましたか?

    キャンセル

  • 2018/01/20 16:29

    >Orlofsky様
    申し訳ございません、ソース全文に修正いたしました。
    Button2_Clickは正常に動作しております。
    Windowsが当方はWin10 Home です。
    VSのバージョンはVisual Studio2017 Communityです。

    キャンセル

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

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

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