我的OleDbCommand参数不起作用

时间:2013-07-17 08:20:48

标签: c# oledbcommand

我是C#的新手,不知道我做错了什么。试图找到解决方案,但失败了。提前谢谢。

当我不使用参数“select *fromΚαρτέλα_Ασθενή”时;表单将填充读者的值。表单不会带来值,换句话说就像select命令不起作用。

            OleDbCommand cmd = new OleDbCommand();
            cmd.CommandType = CommandType.Text;
            cmd.CommandText = "select * from Καρτέλα_Ασθενή where Κωδ_Ασθενή = @Κωδ_Ασθενή";
            cmd.Parameters.AddWithValue("@Κωδ_Ασθενή", MyGlobals.Patient_code);
            cmd.Connection = accessdb;
            accessdb.Open();

            OleDbDataReader dr = cmd.ExecuteReader();
            if (dr.Read())
            {
                while (dr.Read())
                {
                    txt_patient_code.Text = dr["Κωδ_Ασθενή"].ToString();
                    txt_Surname.Text = dr["Επώνυμο"].ToString();
                    txt_Name.Text = dr["Όνομα"].ToString();
                    txt_date.Text = Convert.ToDateTime(dr["Ημερομηνία_Γέννησης"]).ToShortDateString();
                    txt_address.Text = dr["Διεύθυνση"].ToString();
                    txt_area.Text = dr["Περιοχή"].ToString();
                    txt_phone.Text = dr["Τηλ"].ToString();
                    txt_fax.Text = dr["Φαξ"].ToString();
                    txt_insurance.Text = dr["Ασφάλεια"].ToString();
                    txt_comments.Text = dr["Παρατηρήσεις"].ToString();
                    txt_history.Text = dr["Ιστορικό"].ToString();
                    txt_alergies.Text = dr["Αλλεργίες"].ToString();
                    txt_email.Text = dr["e-mail"].ToString();
                }
            }
            dr.Close();
            accessdb.Close();

2 个答案:

答案 0 :(得分:1)

删除while循环,如下所示

if (dr.Read())
{
  txt_patient_code.Text = dr["Κωδ_Ασθενή"].ToString();
  //..... set all other text box values 

}

如果你只有一个记录与你的sql匹配,那么在第一个dr.Read()中它将获取该记录。当你来到while循环时,没有从数据库中获取的记录。

并且可能有列允许空值,在调用string方法之前,最好检查dbnull

 txt_email.Text = dr["Επώνυμο"] == DBNull.Value ? string.Empty : dr["Επώνυμο"].ToString();

答案 1 :(得分:0)

好吧,我发现你的代码存在一些问题,但我并不完全理解你的问题,所以我会尽可能多地回答你的问题。 首先,正如我所写,删除if (dr.Read()),因为while循环已经这样做了。 现在,你的循环内部存在一个问题,因为这意味着如果你有几个项目,它们将覆盖前一个项目,你将留下最后一个项目值,所以你必须计算你想要做什么数据,可能是dataGrid或其他。

在您的问题中,您正在谈论您的查询,如果您未在MyGlobals.Patient_code中放置值,则查询仍然有效,至少我认为这就是您的意思。可能是因为你留下了数据库中可能有的最后一个值或string.empty值。检查数据库以及每次到达该行时的价值,如果您需要进一步的帮助,请告诉我们您的问题的更多信息