Pergunta

Como para encapsular abaixo códigos (Eu preciso refoctoring)

    public class mycollection
{
        private DateTime tarih;
        private int sira;
        private int visitingcount;

        public DateTime TARIH { get { return tarih; } set { tarih = value; } }
        public int SIRA { get { return sira; } set { sira = value; } }
        public int VISITINGCOUNT { get { return visitingcount; } set { visitingcount = value; } }
}

eu usei essa classe abaixo

DataRow[] rows = dsChart.Tables[0].Select("TARIH>='" + DateGap1 + "' and TARIH<='" + DateGap2 + "'");

                                list = new List<mycollection>();
                                foreach (DataRow dr in rows)
                                {
                                    mycollection mycol = new mycollection();
                                    mycol.TARIH = Convert.ToDateTime(dr["TARIH"].ToString());
                                    mycol.SIRA = Convert.ToInt32(dr["SIRA"].ToString());
                                    mycol.VISITINGCOUNT = Convert.ToInt32(dr["VISITINGCOUNT"].ToString());
                                    list.Add(mycol);
                                }

Eu preciso gostar que:

  public static void LoadDepartman(string departmanName)
        {
            List<StuffDepartman> li = new List<StuffDepartman>();
            GetDepartman departman = new GetDepartman();
            DataSet ds = departman.GetDepartmanA(departmanName);
            foreach (DataRow dr in ds.Tables[0].Rows)
            {
                li.Add(new StuffDepartman
                {
                    Name = dr["Name"].ToString(),
                    SurName = dr["SurName"].ToString(),
                    Address = dr["Address"].ToString(),
                    Phone = dr["Phone"].ToString(),
                    DepartmanName = dr["DepartmanName"].ToString(),
                    Salary =int.Parse( dr["Salary"].ToString()),
                    Married = dr["Married"].ToString()
                }
                );
            }
            HttpContext.Current.Session["Stuffs"] = li;

        }

Nenhuma solução correta

Outras dicas

(eu não entender completamente como os dois primeiros exemplos referem-se ao terceiro ... eles não parecem nada têm em comum)

Então, o que atualmente breaks? O maior problema que vejo é que (IIRC) ser confiável utilizável com Session (com diferentes implementações de back-end) o item deve ser serializável (var BinaryFormatter), mas que pode ser tão simples como mycollection marcação com [Serializable].

Para informações mycollection é um nome confuso para algo que é um entidade linha , não a coleção real - e se você tiver C # 3.0 você pode simplificar as coisas um pouco com propriedades automattically implementadas:

[Serializable]
public class SomeSensibleName
{
    public DateTime Tarih {get;set;}
    public int Sira {get;set;}
    public int VisitCount {get;set;}
}

No entanto; não está claro (do seu código) se isso vai mudar nada. Por favor, você pode esclarecer o que está acontecendo atualmente?

Se bem entendi, esta é a refatoração que você está procurando:

DataRow[] rows = dsChart.Tables[0].Select("TARIH >='" + DateGap1 + "' and TARIH <='" + DateGap2 + "'");
List<mycollection> list = new List<mycollection>();
foreach (DataRow dr in rows)
{
    list.Add(new mycollection
    {   
      TARIH = Convert.ToDateTime(dr["TARIH"].ToString());
      SIRA = Convert.ToInt32(dr["SIRA"].ToString());
      VISITINGCOUNT = Convert.ToInt32(dr["VISITINGCOUNT"].ToString());
    });
}

Tenha em mente que para que isso funcione, você precisa estar executando o .NET Framework 3.x (VS2008).

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top