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

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

ただいまの
回答率

90.01%

C#

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 660

sosuke_21

score 10

コード

using System;
using System.Windows.Forms;
using System.Data.OleDb;
using System.Text.RegularExpressions;

namespace DBselect_2
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
int id;
string name;
DateTime birth;
int score;

private void label1_Click(object sender, EventArgs e)
{

}

private void button2_Click(object sender, EventArgs e)
{
}

private string escapeString(string iName)
{
string str = "%" + Regex.Replace(iName, "[_%\\[#]", "#$0") + "%";
return str;
}

private void button1_Click(object sender, EventArgs e)
{
OleDbConnection conn = new OleDbConnection();
OleDbCommand command = new OleDbCommand();

conn.ConnectionString = @"Provider = Microsoft.Jet.OLEDB.4.0; Data Source = C:\db\db2.mdb";

conn.Open();

string iID = textBox2.Text;
string iName = textBox3.Text;
string iBirth = textBox4.Text;
int flg = 0;

string sql = "SELECT * FROM t_member WHERE ";
if (iID != "")
{
sql += "   ID = @ID";
OleDbParameter pID = new OleDbParameter("@ID", iID);
command.Parameters.Add(pID);
flg = 1;

}
if (iName != "")
{
if (flg != 0)
{
sql += " and ";
}
sql += " m_name like @NAME ";
string eName = escapeString(iName);
OleDbParameter pName = new OleDbParameter("@NAME", eName);
command.Parameters.Add(pName);
flg = 1;
}
if (iBirth != "")
{
if (flg != 0)
{
sql += "  and ";
}
sql += " m_birth = @BIRTH ";
OleDbParameter pBirth = new OleDbParameter("@BIRTH", iBirth);
command.Parameters.Add(pBirth);
flg = 1;
}
if (flg == 0)
{
return;
}

command.CommandText = sql;
command.Connection = conn;

OleDbDataReader reader = command.ExecuteReader();
memberDataSet.Clear();

while (reader.Read())
{
id = reader.GetInt32(0);
name = reader.GetString(1);
birth = reader.GetDateTime(2);
score = reader.GetInt32(3);

Console.WriteLine("ID:" + id + "名前:" + name + "生年月日:" + birth + "最高値" + score);

}
conn.Close();
}
}
}

?

※accessのデータと連携させて作成しています。

入力したデータが出力はされますが、まるで囲った部分に表示させたいのですがどうしたらいいでしょうか?

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

+1

id,nameなどはただの変数なので
textBox2.Textでテキストボックスの文字が設定できるように、
listコンポーネントを指定して対象の行、列に対して値を設定しないとダメです。

listの使い方はググってください。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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