How remove records from datagrid in asp.net if condition satisfy

后端 未结 2 997
梦谈多话
梦谈多话 2021-01-17 06:38

I have a datagrid declare like this in ascx file:



        
相关标签:
2条回答
  • 2021-01-17 07:13

    Good practice is to populate datareader based on required criteria.

    In case you want to filter records from datareader, you can load it into datatable.

    IDataReader rdr = Syntegra.Manufacturing.WMCCM.Companies.Companies.ListCompanies(dgCompanies.CurrentPageIndex, pageSize, CompanyList, CompanyNameStartsWith, ProcessSqlClause, SkillSqlClause, LocationClause, KeywordSqlClause, User, Status, SearchPortalId, false, sortColumn, sortDirection);
    DataTable dt = new DataTable();
    dt.Load(rdr);
    rdr.Close();
    
    
    for(int i = dt.Rows.Count-1; i >= 0; i--)
    {
       DataRow dr = dt.Rows[i];
    
       int iCompanyId = Convert.ToInt(dr["CompanyId"]);
    
       if (IsCompanyHavingChoiceYes(iCompanyId))
        dr.Delete();
    }   
    
    
    dt.AcceptChanges();
    
    dgCompanies.PageSize = pageSize;
    dgCompanies.DataSource = dt;  //provide datatable as datasource
    dgCompanies.DataBind();
    

    Method to check from database:

    private  bool IsCompanyHavingChoiceYes(int iCompanyId)
        {            
            string commandText = @"SELECT cn.companyId from companies cn 
                       INNER JOIN UserCompany uc ON uc.companyid = cn.companyid 
                       INNER JOIN Users u ON u.userId = uc.userId
                       INNER JOIN Choice c ON c.Email = u.Email And c.Choice = @Choice
                       WHERE cn.CompanyId = @CompanyId;";
    
            string connectionString = ConfigurationSettings.AppSettings["connectionString"];
    
            using (SqlConnection connection = new SqlConnection(connectionString))
            {
                SqlCommand command = new SqlCommand(commandText, connection);
                command.Parameters.AddWithValue("@CompanyId", iCompanyId);
                command.Parameters.AddWithValue("@Choice", "YES");
    
                try
                {
                    connection.Open();
                    using (SqlDataReader reader = command.ExecuteReader())
                    {
                        return reader.HasRows;
                    }
    
                    return false;
                }
                catch (Exception ex)
                {
                    return false;
                }
    
            }
        }
    

    http://i.stack.imgur.com/rPy3A.png

    0 讨论(0)
  • 2021-01-17 07:24

    You cannot directly filter the IDataReader since it will be read like one by one.

    What you can simply do is load all the data from datareader into DataTable using a Load() method.

    IDataReader rdr = Syntegra.Manufacturing.WMCCM.Companies.Companies.
                      ListCompanies(dgCompanies.CurrentPageIndex, pageSize, CompanyList,
                      CompanyNameStartsWith, ProcessSqlClause, SkillSqlClause, 
                      LocationClause, KeywordSqlClause, User, Status, SearchPortalId, false, 
                      sortColumn, sortDirection);
    DataTable dt = new DataTable();
    dt.(rdr);
    //For filtering all the CompanyID column value not equal to  5
    DataRow[] filteredRows=DataTable.Select("[CompanyID] <> 5 " ); 
    
    dgCompanies.PageSize = pageSize;
    dgCompanies.DataSource = filteredRows;
    dgCompanies.DataBind();
    
    0 讨论(0)
提交回复
热议问题