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

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

ただいまの
回答率

90.04%

C# 文字列の部分一致

受付中

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 1,884

sosuke_21

score 10

前提・実現したいこと

ここに質問したいことを詳細に書いてください
(例)PHP(CakePHP)で●●なシステムを作っています。  
■■な機能を実装中に以下のエラーメッセージが発生しました。

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

エラーメッセージ

型 'System.Data.OleDb.OleDbException' のハンドルされていない例外が System.Data.dll で発生しました

該当のソースコード

ここにご自身が実行したソースコードを書いてください


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();
}

private void label1_Click(object sender, EventArgs e)
{

}

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

int ID;
string Name;
DateTime Birth;

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);

Console.WriteLine("ID:" + iID + "名前:" + iName + "生年月日:" + iBirth);

}
conn.Close();
}

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

private void button1_Click(object sender, EventArgs e)
{

}
}
}

試したこと

課題に対してアプローチしたことを記載してください

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

より詳細な情報

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • 退会済みユーザー

    2016/07/04 11:08

    こちらの質問が他のユーザから「やってほしいことだけを記載した丸投げの質問」という指摘を受けました
    「質問を編集する」ボタンから編集を行い、調査したこと・試したことを記入していただくと、回答が得られやすくなります。

  • coco_bauer

    2016/07/04 17:47

    try - catchが無いのですから、発生した例外はハンドルされないです。発生したのはOLE DB関連の例外ですが、どうして「文字列の部分一致」というタイトルなのですか????

    キャンセル

回答 1

0

見づらいので </> を押してコードを囲ってください。
ざっと見たところ、conn と command が関連付けられていないようです。
command.Connection = conn としてください。

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(); 
        }

        private void label1_Click(object sender, EventArgs e) 
        {

        }

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

            int ID; 
            string Name; 
            DateTime Birth;

            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);

                Console.WriteLine("ID:" + iID + "名前:" + iName + "生年月日:" + iBirth);

            } 
            conn.Close(); 
        }

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

        private void button1_Click(object sender, EventArgs e) 
        {

        } 
    } 
}

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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