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

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

ただいまの
回答率

89.70%

テキストボックスにテキストとDBのデータを比べる方法について

受付中

回答 2

投稿

  • 評価
  • クリップ 1
  • VIEW 1,374

mimi3103

score 6

 前提・実現したいこと

Visual Studio2017のWindows Formアプリケーションにて,アプリを作成中です.
Form画面には,ボタンが2つと,テキストボックスが1つ,DataGridViewが1つ配置されています.
また,SQLiteにてDBを作成しました.テキストボックスに入力された文字列や数字が
DBの中にあるかどうかを判別するプログラムを書きたいです.ボタン1がクリックされると
DBに接続し,テーブルの作成やデータの追加などを行います.そしてボタン2が押されると
それらをDataGridViewに表示します. このボタン2をクリックしたときに,テキストボックスに入力された
テキストと,DBの中のデータと1つでも一致したら,OKとLabelに表示するプログラムを作成したいです.

 発生している問題・エラーメッセージ

TextBoxのテキストを変数に格納して,SELECT FROM WHERE INの中で検索しようとしたのですが,
変数が認識されません.
ソースコードいろいろと変更した結果中途半端な内容ですが
貼っておきます.

 該当のソースコード

sing 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;
using System.IO;

namespace Database_1018
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
        string path = "test.db";

        private void button1_Click(object sender, EventArgs e)
        {
            // テーブルを作成 (test.dbを新規で作成する場合のみ)
            if (File.Exists(path) == false)
            {
                using (SQLiteConnection con = new SQLiteConnection("Data Source=" + path))
                {
                    // DataBase接続開始
                    con.Open();
                    using (SQLiteCommand cmd = con.CreateCommand())
                    {
                        cmd.CommandText = "CREATE TABLE Lesson (社員ID INTEGER, name NVARCHAR(10), 年齢 INTEGER, 部署名 NVARCHAR(10), パスワード INTEGER)";
                        cmd.ExecuteNonQuery();
                    }
                }

            }

            using (SQLiteConnection con = new SQLiteConnection("Data Source=" + path))
            {
                con.Open();
                using (SQLiteCommand cmd = con.CreateCommand())
                {
                    con.Open();
                    cmd.CommandText = "INSERT INTO Lesson (社員ID,name,年齢,部署名,パスワード) VALUES(1000,'TOM',23,'開発技術部',11111111)";
                    cmd.ExecuteNonQuery();
                    cmd.CommandText = "INSERT INTO Lesson (社員ID,name,年齢,部署名,パスワード) VALUES(2000,'MIKE',23,'開発技術部',22222222)";
                    cmd.ExecuteNonQuery();
                    cmd.CommandText = "INSERT INTO Lesson (社員ID,name,年齢,部署名,パスワード) VALUES(3000,'JOHN',25,'開発技術部',33333333)";
                    cmd.ExecuteNonQuery();
                    cmd.CommandText = "INSERT INTO Lesson (社員ID,name,年齢,部署名,パスワード) VALUES(4000,'EMI',23,'開発技術部',44444444)";
                    cmd.ExecuteNonQuery();
                }
            }
        }
        private DataTable dataTable = new DataTable();

        protected override void OnLoad(EventArgs e)
        {
            dataGridView1.DataSource = dataTable;
            base.OnLoad(e);
        }

        private void button2_Click(object sender, EventArgs e)
        {
            string text1;
            text1 = textBox1.Text;

            using (SQLiteConnection con = new SQLiteConnection("Data Source=" + path))
            {
                con.Open();
                using (SQLiteDataAdapter adapter = new SQLiteDataAdapter("SELECT * FROM Lesson", con))
                adapter.Fill(dataTable);

                try
                {
                    string sql = "select * from lesson where text1";

                    SQLiteCommand com = new SQLiteCommand(sql, con);
                    SQLiteDataReader sdr = com.ExecuteReader();
                }
                finally
                {
                    con.Close();
                }
            }
        }
    }
}

 補足情報(FW/ツールのバージョンなど)

Visual Studio 2017 C# Windows Form アプリケーション SQLite

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

+1

string sql = "select * from lesson where text1";

上記の書き方が意図しているものと違っている気がします。以下のように変更して試してみたらいかがでしょうか。
name列で検索する前提ですが・・・

string sql = "select * from lesson where name =" + text1;

ダブルクォーテーション内の文字列は、特別な場合をのぞいてただの文字列として扱われます。
変数として扱いたい場合は、上記の通り文字列と連結するなどしてやらないといけません。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/10/22 14:37

    実行するSQLを確認しましょう。
    SQLiteで文字列を比較するときはシングルクォーテーションで囲まないといけません。
    DBが絡む処理のデバッグを行う場合、実行されるSQLがどうなっているかは意識しないとできませんので
    確認する癖をつけましょう。

    キャンセル

  • 2018/10/22 15:14

    YAmaGNZさんのおっしゃる通りで、私のサンプルにシングルクォーテーションが抜けておりました。
    正しくは以下ですね。

    string sql = "select * from lesson where name ='" + text1 + "'";

    本来はstring.Format()等使ってもう少し見やすく書きたいところですが、問題の本質とは異なるのでここでは割愛させていただきます。

    キャンセル

  • 2018/10/25 23:13

    お二方,回答ありがとうございました.
    そうですね...知識不足でした.これから勉強を進めてまいります.

    シングルクォーテーションで囲んだところ,無事,求めていた機能を実現することができました.
    みなさんありがとうございました!

    キャンセル

0

ボタン2押したときに、DBからdatagridviewにデータを表示後、テキストの内容とDBを比較とのことですが、DBは他のユーザーから変更されていることは考えないのでしょうか?もし、変更されているとしたら
okとなっても、datagridviewには存在しないデータで合致する現象が発生すると思います。
この場合、DBと比較するのではく、datagridviewの内容と比較するほうが確実なのではないでしょうか?

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/10/25 23:12

    回答ありがとうございます!
    今回は他のユーザからの変更は考慮しなくて問題ありませんでした.
    すみません,記載しておくべきでした...

    キャンセル

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

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

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