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

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

ただいまの
回答率

88.92%

DBから取得した結果をC#でラベルに表示したい

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 4,206

maam

score 55

会員の検索表示画面を作成しています。
検索表示画面で姓を入力し検索ボタンを押すと、該当する会員のフルネーム、電話番号、住所が表示されるプログラムを作っています。
SQL文で検索条件を書き、検索結果をラベルに表示したいです。結果はひとつではなく、複数該当する場合は全ての結果を表示するのが条件です。
var adapter = new SqlDataAdapter(command);
adapter.Fill(table);

いろいろ調べてみるとこういった形が多いのですが、これでは全ての検索結果を表示できませんでした。なにかアドバイスをいただけないでしょうか。

    private void KensakuBt_Click(object sender, EventArgs e)
        {
            // 接続文字列の取得
            var connectionString = ConfigurationManager.ConnectionStrings["sqlsvr"].ConnectionString;

            // データベース接続の準備
            using (var connection = new SqlConnection(connectionString))
            using (var command = connection.CreateCommand())
            {

                String sei = textBox1.Text;
                String mei = textBox2.Text;
                String man = radioButton1.Text;
                String woman = radioButton2.Text;
                String yuubin = textBox3.Text;
                try
                {
                    //データベースの接続開始
                    connection.Open();

                    // SQLの条件設定
                    command.CommandText =
                    @"SELECT TOP 10 count *  FROM MEMBER_MASTER"   //上位10件の表示
                    + "WHERE MEMBER_MASTER.name1 LIKE '%" + sei + "%'"  //姓との部分一致
                    + "WHERE MEMBER_MASTER.name2 LIKE '%" + mei + "%'"  //名との部分一致
                    + "WHERE MEMBER_MASTER.gender = " + man
                    + "WHERE MEMBER_MASTER.gender = " + woman
                    + "WHERE MEMBER_MASTER.adress = " + yuubin
                    + "ORDER BY MEMBER_MASTER.id";          //IDの昇順に表示

この後にどう表示すればよいでしょうか

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • YAmaGNZ

    2018/12/03 15:06 編集

    もう少し落ち着いて質問の修正をされたほうがよろしいかと思います。修正されたコードですと、SQLを実行していませんし、構築したSQLも実行できないものになっています。

    キャンセル

  • maam

    2018/12/04 11:51

    皆様ご指摘いただきありがとうございます。皆様のおっしゃる通りです。質問を投げやりの状態にしていたらいつまでたっても理解できないと思うので、ここに頼らないようにします。すみません

    キャンセル

  • Zuishin

    2018/12/04 12:04

    頼る頼らない以前にいつまでも未解決で置いておかず解決してください。

    キャンセル

回答 1

checkベストアンサー

0

まず、現在のコードはSQL部分が適切ではありません。

  • 「複数該当する場合は全ての結果を表示する」のであれば、 TOP 10 count  という部分は不要
  • WHERE が何度も登場するのはSQL文法的にNG(複数の条件を記述する場合は AND や OR を使用する)

詳しく説明するためには、検索対象のテーブル構造を示していただく必要があります。
(その場合は create table 文だと回答しやすいです)
現在は示されていないため、SQL部分の詳しい説明は省きます。
(SQLについての参考書などを確認するか、あるいはSQL単体で別途質問を起こしてください)

SQL Server に接続して情報を参照する方法については、こちら↓が参考になるかと思います。
C# で SQL Server から SELECT文 の 実行結果 を 取得する 方法 - galife
「1行ずつ読み込む (SqlDataReader)」の方法を採用したとして、以下のようなコードになるでしょうか。
※説明を簡単にするため、検索結果を List<string> に格納しています
※実際に動作確認をしたわけではないので誤りが含まれている可能性があります、すみません
※★の箇所は適宜見直してください

// 検索結果格納用
var results = new List<string>();

// 接続文字列の取得
var connectionString = ConfigurationManager.ConnectionStrings["sqlsvr"].ConnectionString;

// データベース接続の準備
using (var connection = new SqlConnection(connectionString))
using (var command = connection.CreateCommand())
{
    string sei = textBox1.Text;
    string mei = textBox2.Text;
    string man = radioButton1.Text;
    string woman = radioButton2.Text;
    string yuubin = textBox3.Text;
    try
    {
        //データベースの接続開始
        connection.Open();

        // SQLの条件設定 ★要件に対して適切なSQL文かどうかが不明なため、適宜変更してください
        command.CommandText =
        @"SELECT * FROM MEMBER_MASTER"
        + "WHERE MEMBER_MASTER.name1 LIKE '%" + sei + "%'" //姓との部分一致
        + "AND  MEMBER_MASTER.name2 LIKE '%" + mei + "%'" //名との部分一致
        + "AND  MEMBER_MASTER.gender = " + man
        + "AND  MEMBER_MASTER.gender = " + woman
        + "AND  MEMBER_MASTER.adress = " + yuubin
        + "ORDER BY MEMBER_MASTER.id"; //IDの昇順に表示

        // SQLを実行し、結果を results に格納する
        using (var reader = command.ExecuteReader())
        {
            while (reader.Read() == true)
            {
                results.Add(
                    /*フルネーム*/(reader["name1"] as string) + (reader["name2"] as string) + " " +
                    /*電話番号*/  (reader["tel"/*★列名は適宜変更してください*/] as string) + " " +
                    /*住所*/      (reader["adress"] as string)
                );
            }
        }
    }
    catch (Exception exception)
    {
        Console.WriteLine(exception.Message);
        throw;
    }
    finally
    {
        // データベースの接続終了
        connection.Close();
    }
}

// results の内容をラベルに表示
// ★label1 というラベル(AutoSizeプロパティがtrue)がどこかに存在し、そこに表示するものとします
string resultText = string.Empty;
foreach (string item in results)
{
    resultText += item + "\r\n";
}
label1.Text = resultText;

いくつか不明な点はありましたが、とりあえずわかる範囲で回答しました。
いろいろわからない中での手探りは大変かと思いますが、頑張ってください。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/12/04 11:57

    algさん
    丁寧なご回答、本当にありがとうございます。コピペするだけでなく、コメントと共に1文1文を読んでいくと意味が理解できました!labelへの表示についてはもうひと工夫必要みたいなので、あとは自力で頑張ってみます。本当にありがとうございます。

    キャンセル

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

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

関連した質問

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