所以我有两个表单。一个是主表单,其中包含一个递送列表框,其中数据从数据库加载。另一个表单是交付表单,当用户从列表框中选择交付时,其详细信息应显示在交付表单中。到目前为止,我已经成功地加载了数据,并在我的交付表单中显示了一些文本。但是,我无法让我的交付表单显示列表框中所选交付的数据。
下面是我的一小段代码:
private void FrmDelivery_Load(object sender, EventArgs e)
{
SqlConnection con = new SqlConnection(@"Data  Source=.\SQLEXPRESS;AttachDbFilename=|DataDirectory|\visits.mdf;Integrated  Security=True;User Instance=True");
con.Open();
SqlCommand cmd = new SqlCommand("SELECT CustomerName, CustomerAddress, ArrivalTime FROM   tblVisits", con);
SqlDataReader sdr = cmd.ExecuteReader();
while (sdr.Read())
{
this.txtCustomerName.Text = sdr["CustomerName"].ToString(); 
this.txtCustomerAddress.Text = sdr["CustomerAddress"].ToString();
this.txtArrivalTime.Text = sdr["ArrivalTime"].ToString();
}
sdr.Close();
if (theDelivery != null)
{
txtCustomerName.Text = theDelivery.customerName;
txtCustomerAddress.Text = theDelivery.customerAddress;
txtArrivalTime.Text = theDelivery.arrivalTime;
}
}发布于 2013-11-08 21:20:09
我会这样使用:
public string Get_Field(SqlConnection con, string Table,string Field,string where)
{
       DataSet RS_Temp = new DataSet();
       SqlDataAdapter DA;
       string SqlStr = "SELECT " &  Field &  " FROM " & Table;
       //Add an "If statment" if there is a where condition....
       DA = new OleDbDataAdapter(SqlStr, con);
       DA.Fill(RS_Temp, Table_Name);
            if (RS_Temp.Tables[Table_Name].Rows.Count == 0)
            {
                return ("");
            }
            if (System.Convert.IsDBNull(RS_Temp.Tables[Table_Name].Rows[0][0]))
            {
                return ("");
            }
            if (RS_Temp.Tables[Table_Name].Rows.Count != 0)
            {
                return (RS_Temp.Tables[Table_Name].Rows[0][0].ToString());
            }
            return ("");
}当然,别忘了添加Try & catch:
YOURTEXTBOX.Text = Get_Field(...)https://stackoverflow.com/questions/13568957
复制相似问题