[C#] DataTable을 반복하는 방법

를 통해 반복해야합니다 DataTable. 라는 열이 ImagePath있습니다.

내가 사용할 때 나는 DataReader이렇게한다 :

SqlDataReader dr = null;
dr = cmd.ExecuteReader();
while (dr.Read())
{
    TextBox1.Text = dr["ImagePath"].ToString();
}

를 사용하여 같은 것을 어떻게 달성 할 수 DataTable있습니까?



답변

DataTable dt = new DataTable();

SqlDataAdapter adapter = new SqlDataAdapter(cmd);

adapter.Fill(dt);

foreach(DataRow row in dt.Rows)
{
    TextBox1.Text = row["ImagePath"].ToString();
}

… 연결이 열려 있고 명령이 올바르게 설정되었다고 가정합니다. 또한 구문을 확인하지는 않았지만 아이디어를 제공해야합니다.


답변

foreach (DataRow row in myDataTable.Rows)
{
   Console.WriteLine(row["ImagePath"]);
}

나는 이것을 메모리에서 쓰고 있습니다.
이것이 객체 모델을 이해하기에 충분한 힌트를 제공하기를 바랍니다.

DataTable-> DataRowCollection-> DataRow(columnName 또는 서수를 사용하여 해당 행의 열 내용을 사용하고 찾을 수 있음).

-> = 포함합니다.


답변

DataSet에 linq 확장자를 사용할 수도 있습니다.

var imagePaths = dt.AsEnumerble().Select(r => r.Field<string>("ImagePath");
foreach(string imgPath in imagePaths)
{
    TextBox1.Text = imgPath;
}


답변

위의 예는 매우 유용합니다. 그러나 특정 행에 특정 값이 있는지 여부를 확인하려는 경우. 그렇다면 삭제하고 중단하고 값을 찾지 못하면 직선 오류가 발생합니다. 아래 코드가 작동합니다.

foreach (DataRow row in dtData.Rows)
        {
            if (row["Column_name"].ToString() == txtBox.Text)
            {
                // Getting the sequence number from the textbox.
                string strName1 = txtRowDeletion.Text;

                // Creating the SqlCommand object to access the stored procedure
                // used to get the data for the grid.
                string strDeleteData = "Sp_name";
                SqlCommand cmdDeleteData = new SqlCommand(strDeleteData, conn);
                cmdDeleteData.CommandType = System.Data.CommandType.StoredProcedure;

                // Running the query.
                conn.Open();
                cmdDeleteData.ExecuteNonQuery();
                conn.Close();

                GetData();

                dtData = (DataTable)Session["GetData"];
                BindGrid(dtData);

                lblMsgForDeletion.Text = "The row successfully deleted !!" + txtRowDeletion.Text;
                txtRowDeletion.Text = "";
                break;
            }
            else
            {
                lblMsgForDeletion.Text = "The row is not present ";
            }
        }


답변