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

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

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

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

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。

解決済

C#で住所録を作成中。検索ボタンについて質問

ICCI
ICCI

総合スコア0

C#

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

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。

1回答

0評価

0クリップ

26閲覧

投稿2019/08/14 13:09

編集2022/01/12 10:58

前提・実現したいこと

visual studio2019フォームアプリケーションでC#を使い住所録を作っています初心者です。
画面はテキストボックス1つと検索ボタン1つ。終了ボタン1つ。
データベースに接続し、dataGridViewに結果を表示させます。

MySqlへの接続、初期表示時のデータの表示はできたのですが、
検索ボタンの実装の仕方が色々と調べてもいまいち分かりません。
テキストボックスに都道府県を入力後、検索ボタン押下で入力した都道府県に一致するデータをdataGridViewに表示させたいです。

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

現在は検索ボタン内ソースの
try
{
conn.open(); 
以下でエラーになります。
DBへの接続の仕方が悪いのでしょうか?

該当のソースコード

//検索ボタン private void Button1_Click_1(object sender, EventArgs e) { //テキストボックスの文字取得 string prefecture = AddressSrc.Text; if (prefecture == "") { MessageBox.Show("都道府県を入力してください"); } else { MySqlConnection conn = new MySqlConnection(Properties.Settings.Default.address_noteConnectionString); MySqlCommand sqlCommand = new MySqlCommand("SELECT NAME1, NAME2, ZIP1, ZIP2, ADDRESS1, ADDRESS2, ADDRESS3, TEL FROM mst_address WHERE ADDRESS1 = @ADDRESS1", conn); DataTable dt = new DataTable(); conn.ConnectionString = Properties.Settings.Default.address_noteConnectionString; try { conn.Open(); sqlCommand.CommandText = "SELECT NAME1,NAME2,ZIP1,ZIP2,ADDRESS1,ADDRESS2,ADDRESS3,TEL FROM mst_address WHERE ADDRESS1 = @ADDRESS1"; sqlCommand.Connection = conn; sqlCommand.Parameters.Add(new MySqlParameter("@ADDRESS1", prefecture)); MySqlDataReader reader = sqlCommand.ExecuteReader(); dt.Load(reader); dataGridView1.DataSource = dt; reader.Close(); }

補足情報

現在の全ソースを載せさせて頂きます。よろしくお願いします、

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 MySql.Data.MySqlClient;
using System.Data.SqlClient;
using System.Text.RegularExpressions;
using AddressList.Properties;

namespace AddressList
{
public partial class AddressList : Form
{
public AddressList()
{
InitializeComponent();
}

public void 住所一覧_Load(object sender, EventArgs e) { // MySQLへの接続 using (MySqlCommand command = new MySqlCommand()) { // MySQLへの接続情報 string server = "localhost"; // MySQLサーバホスト名 string database = "address_note"; // 接続するデータベース名 string user = "ユーザ名"; // MySQLユーザ名 string pass = "パスワード"; // MySQLパスワード string address_noteConnectionString = string.Format("Server={0};Database={1};Uid={2};Pwd={3}", server, database, user, pass); // MySQLへの接続 MySqlConnection conn = new MySqlConnection(address_noteConnectionString); conn.ConnectionString = "server=localhost; user id=root; Password=root; database=address_note"; //DBとの接続オープン conn.Open(); //データを保存するテーブル作成 DataTable dt = new DataTable(); //SQL文と接続情報を引数に、データアダプターを作成 MySqlDataAdapter da = new MySqlDataAdapter("SELECT NAME1,NAME2,ZIP1,ZIP2,ADDRESS1,ADDRESS2,ADDRESS3,TEL FROM mst_address", conn); //DataSet ds = new DataSet(); //SQL文で指定したデータをDataTableに格納 da.Fill(dt); //表示させる dataGridView1.DataSource = dt; //DBとの接続クローズ conn.Close(); dataGridView1.Columns[1].HeaderText = "氏名"; dataGridView1.Columns[2].HeaderText = "郵便番号"; dataGridView1.Columns[3].HeaderText = "都道府県"; dataGridView1.Columns[4].HeaderText = "市区町村以下"; dataGridView1.Columns[5].HeaderText = "電話番号"; dataGridView1.Columns["DelBtn"].DisplayIndex = 5; } } //検索ボタン private void Button1_Click_1(object sender, EventArgs e) { //テキストボックスの文字取得 string prefecture = AddressSrc.Text; if (prefecture == "") { MessageBox.Show("都道府県を入力してください"); } else { MySqlConnection conn = new MySqlConnection(Properties.Settings.Default.address_noteConnectionString); MySqlCommand sqlCommand = new MySqlCommand("SELECT NAME1, NAME2, ZIP1, ZIP2, ADDRESS1, ADDRESS2, ADDRESS3, TEL FROM mst_address WHERE ADDRESS1 = @ADDRESS1", conn); DataTable dt = new DataTable(); conn.ConnectionString = Properties.Settings.Default.address_noteConnectionString; try { conn.Open(); sqlCommand.CommandText = "SELECT NAME1,NAME2,ZIP1,ZIP2,ADDRESS1,ADDRESS2,ADDRESS3,TEL FROM mst_address WHERE ADDRESS1 = @ADDRESS1"; sqlCommand.Connection = conn; sqlCommand.Parameters.Add(new MySqlParameter("@ADDRESS1", prefecture)); MySqlDataReader reader = sqlCommand.ExecuteReader(); dt.Load(reader); dataGridView1.DataSource = dt; reader.Close(); } catch { MessageBox.Show("検索エラーです"); } finally { conn.Close(); } } } //テキストボックス private void TextBox1_TextChanged_1(object sender, EventArgs e) { } // 画面を閉じる private void Button2_Click(object sender, EventArgs e) { this.Close(); } private void DataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e) { // 削除ボタンの列かどうかを確認 if (e.ColumnIndex == this.dataGridView1.Columns["DelBtn"].Index) { if (DialogResult.Yes == MessageBox.Show("削除してもよろしいですか?", "削除", MessageBoxButtons.YesNo, MessageBoxIcon.Question)) { // 削除 this.dataGridView1.Rows.RemoveAt(e.RowIndex); MessageBox.Show("削除完了しました。"); } else { this.Close(); } } } }

}

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

nskydiving
nskydiving

2019/08/14 13:19

出ているエラーメッセージを質問欄に記載してください。
gentaro
gentaro

2019/08/14 13:21

> 以下でエラーになります。 書いてない件。 > DBへの接続の仕方が悪いのでしょうか? そこでエラーになるなら間違いなくそう。

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

C#

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

検索

検索は、あるデータの集まりの中から 目的のデータを見つけ出すことです。