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

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

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

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

SQLite

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

Visual Studio

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

Windows 7

Microsoft Windows 7は過去にリリースされたMicrosoft WindowsのOSであり、Windows8の1代前です。2009年の7月にリリースされ販売されました。Windows7の前はWindowsVistaで、その更に3年前にリリースされました。

Q&A

解決済

1回答

6965閲覧

SQLiteConnection Open関数

退会済みユーザー

退会済みユーザー

総合スコア0

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

SQLite

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

Visual Studio

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

Windows 7

Microsoft Windows 7は過去にリリースされたMicrosoft WindowsのOSであり、Windows8の1代前です。2009年の7月にリリースされ販売されました。Windows7の前はWindowsVistaで、その更に3年前にリリースされました。

0グッド

0クリップ

投稿2018/04/23 02:37

タイトルにもありますが、SQLiteConnection Open関数についてです。

現在ファイル選択ダイアログから[.db]ファイルをDataGridViewに表示するというものを作っています。
そこで現在ファイルを選択しそのファイルのフルパスを渡してSQLiteConnectionでオープンしようとしているのですができなくなり、

Invalid ConnectionString format for part "選択したファイルのフルパス", no equal sign found

のような例外が発生して進めません。

C#

1 /// <summary> 2 /// データベースに接続 3 /// </summary> 4 /// <param name="FileName">データベースファイル名</param> 5 public void Open(string FileName) 6 { 7 DbProviderFactory factory = DbProviderFactories.GetFactory("System.Data.SQLite"); 8 using (DbConnection connection = factory.CreateConnection()) 9 { 10 dbConnect = new SQLiteConnection(); 11 // ファイルへ接続 12 dbConnect.ConnectionString = FileName; 13 dbConnect.Open(); 14 } 15 }

コードはこのような感じです。
間違えている箇所やこうしたほうがいい等ありましたらご教示ください。
よろしくお願いいたします。

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2018/04/23 02:57

はい。プロジェクトは同じなのですが、前回はデータの取得部分でして今回はファイル選択をしてデータをオープンするように徐々に改造しています。
guest

回答1

0

ベストアンサー

1,connectionstringsの件

参考 →connectionstringsのページを見る限りでは、ファイルパスだけではconnectionstringsが正しくないと思うのですが。

C#

1var ConnectionString = string.Format("Data Source={0};Version=3;", FileName);

2,connectiondbConnect と2つデーターベースとのコネクションを生成してますが、1つでよいと思われます。あとopenを行いたいだけなので、usingを使う必要はないです。逆に閉じる処で、コネクションのCloseとDisposeを行ってくださいな。

C#

1 public void Open(string FileName) 2 { 3 dbConnect = new SQLiteConnection(string.Format("Data Source={0};Version=3;", FileName)); 4 dbConnect.Open(); 5 } 6

◇参考情報
0. SqliteConnection Constructors

投稿2018/04/23 03:17

編集2018/04/23 05:43
umyu

総合スコア5846

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

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

退会済みユーザー

退会済みユーザー

2018/04/23 05:33

ありがとうございます。 無事オープンできました。 またusingの件ですがまだまだ自分の解釈が良くなかったです。 もっと精進します。 助かりましたありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問