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

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

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

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

VB.NET

Microsoft Visual Basic .NETのことで、Microsoft Visual Basic(VB6)の後継。 .NET環境向けのプログラムを開発することができます。 現在のVB.NETでは、.NET Frameworkを利用して開発を行うことが可能です。

解決済

VB.NETでSQLite 更新

otojiro
otojiro

総合スコア35

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

VB.NET

Microsoft Visual Basic .NETのことで、Microsoft Visual Basic(VB6)の後継。 .NET環境向けのプログラムを開発することができます。 現在のVB.NETでは、.NET Frameworkを利用して開発を行うことが可能です。

2回答

0評価

1クリップ

425閲覧

投稿2018/01/20 02:20

編集2018/01/20 07:26

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ページの「注目」タブのフィードに表示されやすくなります。

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

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

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

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

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

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

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

SQLite

SQLiteはリレーショナルデータベース管理システムの1つで、サーバーではなくライブラリとして使用されている。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

VB.NET

Microsoft Visual Basic .NETのことで、Microsoft Visual Basic(VB6)の後継。 .NET環境向けのプログラムを開発することができます。 現在のVB.NETでは、.NET Frameworkを利用して開発を行うことが可能です。