簡體   English   中英

如何使用數據表在網格視圖中顯示所有數據庫數據?

[英]How to display all Database data in Grid View using Data Table?

我的數據庫中有5個數據,這些數據我想使用數據表顯示在gridView中。 但是我的代碼僅顯示GridView中最后綁定的數據嗎? 我的代碼是。 請指出錯誤?

SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionStrings["ApplicationServices"].ConnectionString);
SqlCommand cmd = new SqlCommand("select Date from MusterRoll where EmpCode='"+code+"' and Month='1' and Year='2015'", conn);
 SqlDataAdapter sda = new SqlDataAdapter(cmd);
 DataSet  ds = new DataSet();
 sda.Fill(ds);
 var rows = ds.Tables[0].Rows;
 foreach (DataRow row in rows)
  {
    string date1 = Convert.ToString(row["Date"]);
    DateTime date2 = Convert.ToDateTime(date1);
    SqlCommand cmd1 = new SqlCommand(" select TOP 1 m.EmpCode,m.NOH,m.OT,m.Late,m.Early,convert(varchar(10),m.Date,103)AS DATE,convert(varchar(10),s1.Shiftname,103)AS Shift From ShiftChange s,ShiftType s1,MusterRoll m  WHERE s1.ShiftID=s.NShiftID and '" + date2 + "'>=Fromdate and Todate>='" + date2 + "' and m.Month = '1' and m.date='"+date2+"' and m.EmpCode='Neena' order by Todate desc", conn);
    SqlDataAdapter sda1 = new SqlDataAdapter(cmd1);
    DataTable  dt = new DataTable();
    sda1.Fill(dt);
    //var rows1 = ds.Tables[0].Rows;
    for (int rowIndex = 0; rowIndex < dt.Rows.Count; rowIndex++)
    {
      DataRow rpw = dt.Rows[rowIndex];
      string EmpCode = rpw.Field<string>("EmpCode");
      string NOH = rpw.Field<string>("NOH");
      string OT = rpw.Field<string>("OT");
      string Latae = rpw.Field<string>("Late");
      string Early = rpw.Field<string>("Early");
      string date3 =rpw.Field<string>("Date");
      string Shift = rpw.Field<string>("Shift");
      gvSingleemp.Visible = true;
      gvSingleemp.DataSource = dt;
      gvSingleemp.DataBind();
         }
        }

在我的shiftChange表中,沒有日期字段,而不是fromDate和ToDate。我想根據MusterRoll表日期顯示員工姓名。 所以首先我選擇MusteRoll date和checkrd這個日期存在於ShiftChange FromDate和ToDate之間(如果存在),顯示Shift

您正在循環綁定GridView數據。 您不需要循環,只需將其綁定到DataTable

SqlDataAdapter sda1 = new SqlDataAdapter(cmd1);
DataTable  dt = new DataTable();
sda1.Fill(dt);
gvSingleemp.DataSource = dt;
gvSingleemp.DataBind();

我仍然認為您根本不需要這些循環。 我想您想從EmpDetails中選擇所有記錄,其中EmpCode = codeMusterRoll.Month='1' and MusterRoll.Year='2015' 然后,您只需要執行一個SQL查詢即可填充一個DataTable ,該數據表gvSingleemp數據源。 那是對的嗎?

如果是這樣,這應該工作(請注意,我使用using語句和sql-parameters):

DataTable tblData = new DataTable();
string sql = @"SELECT ed.EmpCode,ed.Name,ed.Age,ed.Date 
               FROM MusterRoll mr
               INNER JOIN EmpDetails ed 
                  ON mr.Date = ed.Date
               WHERE mr.EmpCode=@EmpCode AND mr.Month=1 AND mr.Year=2015";
using(var conn = new SqlConnection(ConfigurationManager.ConnectionStrings["ApplicationServices"].ConnectionString))
using(var sda = new SqlDataAdapter(sql, conn))
{
    var codeParam = new SqlParameter("@EmpCode", SqlDbType.VarChar).Value = code; // change type accordingly
    sda.SelectCommand.Parameters.Add(codeParam);
    sda.Fill(tblData); // no need for conn.Open/Close with SqlDataAdapter.Fill
}
gvSingleemp.Visible = true;
gvSingleemp.DataSource = tblData;

如果您不想加入表,也可以使用EXISTS

string sql = @"SELECT ed.EmpCode, ed.Name, ed.Age, ed.Date 
               FROM  EmpDetails ed
               WHERE EXISTS
               (
                    SELECT 1 FROM MusterRoll mr
                    WHERE  mr.EmpCode = @EmpCode
                     AND   mr.Month = 1 AND mr.Year=2015
                     AND   mr.Date = ed.Date
               )";

您不必使用循環將DT綁定到GridView:

SqlCommand cmd1 = new SqlCommand(" select EmpCode,Name,Date,Age from  EmpDetails where CompanyID='1'", conn);
 SqlDataAdapter sda1 = new SqlDataAdapter(cmd1);
 DataTable  dt = new DataTable();
 sda1.Fill(dt);
 gvSingleemp.DataSource =dt;
 gvSingleemp.DataBind();
SqlDataAdapter Da = new SqlDataAdapter(cmd);

DataTable  data = new DataTable();

Da.Fill(data);

gvSingleemp.DataSource = data;

gvSingleemp.DataBind();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM