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

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

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

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

SQLite

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

解決済

C#(SQlite)を使い検索画面を実装中です。

yamaguti
yamaguti

総合スコア0

C#

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

SQLite

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

3回答

0評価

0クリップ

3881閲覧

投稿2017/01/24 12:08

編集2022/01/12 10:58

C#(SQlite)を使い検索画面を実装中です。

お世話になります。
検索画面を実装中なのですが、検索条件なしの際は、うまくいくのですが
検索条件を入れたときが結果が取れてきません。

cmd.Parameters["SiteNm"].Value = txtSiteNm.Text;をウォッチで見ると、画面から入力した値が取れている為
後何が足らないのか分かりません。

ご教示の程よろしくお願い致します。

C#

using System; using System\.Collections\.Generic; using System\.ComponentModel; using System\.Data; using System\.Drawing; using System\.Linq; using System\.Text; using System\.Threading\.Tasks; using System\.Windows\.Forms; using System\.Data\.SQLite; namespace WindowsFormsApplication4 { public partial class Itiran : Form { public Itiran\(\) { InitializeComponent\(\); } private void btnsintou_Enter\(object sender, EventArgs e\) { //新規登録ボタンを押下すると登録画面に遷移 Touroku Touroku = new Touroku\(\); Touroku\.Show\(\); this\.Visible = false; } private DataTable datatable = new DataTable\(\); protected override void OnLoad\(EventArgs e\) { dataGridView1\.DataSource = datatable; base\.OnLoad\(e\); } //テーブルの内容を表示 private void buttonkensaku_Click\(object sender, EventArgs e\) { //検索条件がない場合 if \(txtSiteNm\.Text == ""\) { using \(SQLiteConnection con = new SQLiteConnection\("Data Source = C:\\\\Users/BC049/Desktop/WindowsFormsApplication4/myfriend\.sqlite3"\)\) //using \(SQLiteConnection con = new SQLiteConnection\("Data Source = C:\\\\Users/Takaaki Kawabe/Desktop/WindowsFormsApplication4 /myfriend\.sqlite3"\)\) using \(SQLiteDataAdapter adapter = new SQLiteDataAdapter\("select \* from PASS_KANRI", con\)\) { //データグリッドビューのクリア datatable\.Clear\(\); dataGridView1\.DataSource = datatable; adapter\.Fill\(datatable\); //dataGridView1\.Columns\[0\]\.HeaderText = "ID"; //No,SiteNm,LoginId,Password,BIKO カラム順 //テーブルの内容表示 dataGridView1\.Columns\[0\]\.HeaderText = "No"; dataGridView1\.Columns\[1\]\.HeaderText = "サイト名"; dataGridView1\.Columns\[2\]\.HeaderText = "ログインIDまたはEmail等"; dataGridView1\.Columns\[3\]\.HeaderText = "パスワード"; dataGridView1\.Columns\[4\]\.HeaderText = "登録日"; dataGridView1\.Columns\[5\]\.HeaderText = "備考"; } } else { string dbConnectionString = "Data Source = C:\\\\Users/BC049/Desktop/WindowsFormsApplication4/myfriend\.sqlite3"; using \(SQLiteConnection cn = new SQLiteConnection\(dbConnectionString\)\) { cn\.Open\(\); using \(SQLiteTransaction trans = cn\.BeginTransaction\(\)\) { SQLiteCommand cmd = cn\.CreateCommand\(\); //DBセレクト cmd\.CommandText = "SELECT \* from PASS_KANRI where SiteNm = @SiteNm"; //パラメータセット cmd\.Parameters\.Add\("SiteNm", System\.Data\.DbType\.String\); cmd\.Parameters\["SiteNm"\]\.Value = txtSiteNm\.Text; //datatableのクリア datatable\.Clear\(\); //datatableに検索結果をセット datatable\.Load\(cmd\.ExecuteReader\(\)\); dataGridView1\.DataSource = datatable; //dataGridView1\.Columns\[0\]\.HeaderText = "ID"; //No,SiteNm,LoginId,Password,BIKO カラム順 //テーブルの内容表示 dataGridView1\.Columns\[0\]\.HeaderText = "No"; dataGridView1\.Columns\[1\]\.HeaderText = "サイト名"; dataGridView1\.Columns\[2\]\.HeaderText = "ログインIDまたはEmail等"; dataGridView1\.Columns\[3\]\.HeaderText = "パスワード"; dataGridView1\.Columns\[4\]\.HeaderText = "登録日"; dataGridView1\.Columns\[5\]\.HeaderText = "備考"; trans\.Commit\(\); cn\.Close\(\); } } //string dbConnectionString = "Data Source = C:\\\\Users/BC049/Desktop/WindowsFormsApplication4/myfriend\.sqlite3"; ////string dbConnectionString = "Data Source = C:\\\\Users/Takaaki Kawabe/Desktop/WindowsFormsApplication4 /myfriend\.sqlite3"; //using \(SQLiteConnection cn = new SQLiteConnection\(dbConnectionString\)\) //{ // cn\.Open\(\); // using \(SQLiteTransaction trans = cn\.BeginTransaction\(\)\) // { // SQLiteCommand cmd = cn\.CreateCommand\(\); // //select文を走らせる // cmd\.CommandText = "SELECT \* from PASS_KANRI where SiteNm = @SiteNm"; // //パラメータのセット // cmd\.Parameters\.Add\("SiteNm", System\.Data\.DbType\.String\); // cmd\.Parameters\["SiteNm"\]\.Value = txtSiteNm\.Text; // //データグリッドビューのクリア // datatable\.Clear\(\); // var Datatable = new DataTable\(\); // dataGridView1\.DataSource = datatable; // dataGridView1\.Columns\[0\]\.HeaderText = "No"; // dataGridView1\.Columns\[1\]\.HeaderText = "サイト名"; // dataGridView1\.Columns\[2\]\.HeaderText = "ログインIDまたはEmail等"; // dataGridView1\.Columns\[3\]\.HeaderText = "パスワード"; // dataGridView1\.Columns\[4\]\.HeaderText = "登録日"; // dataGridView1\.Columns\[5\]\.HeaderText = "備考"; } } /// <summary> /// /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void dataGridView1_Validating\(object sender, CancelEventArgs e\) { //Clipboard\.SetDataObject\(dataGridView1\.GetClipboardContent\(\)\); //ヘッダーをコピーしないようにする //dataGridView1\.ClipboardCopyMode = // DataGridViewClipboardCopyMode\.EnableWithoutHeaderText; //選択されたセルの内容をクリップボードへコピー //Clipboard\.SetDataObject\(dataGridView1\.GetClipboardContent\(\)\); } private void dataGridView1_CellClick\(object sender, DataGridViewCellEventArgs e\) { //DataGridViewの内容をコピー Clipboard\.SetDataObject\(dataGridView1\.GetClipboardContent\(\)\); } private void Itiran_Load\(object sender, EventArgs e\) { } private void Itiran_KeyDown\(object sender, KeyEventArgs e\) { //Enterキーでコントロール遷移 if \(e\.KeyCode == Keys\.Enter\) { if \(e\.Shift\) { ProcessTabKey\(false\); } else { ProcessTabKey\(true\); } } } } }

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

C#

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

SQLite

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