我是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();
答案 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
值。检查数据库以及每次到达该行时的价值,如果您需要进一步的帮助,请告诉我们您的问题的更多信息