public static EstadoAvaria GetById(int id)
        {
            DBConnection db;
            EstadoAvaria estado = estados.FindLast(x => x.Id == id);
            DataTable    table;

            string denominacao;

            //1º tenta ver se ja tem esse tipo em memoria
            if (estado != null)
            {
                return(estado);
            }

            //Caso nao tenha esse tipo em memoria vai à base de dados
            db    = new DBConnection();
            table = db.Query("SELECT * FROM estado_avaria WHERE id = @0", id);

            //Se o id não existir também na base de dados retorna objeto default
            if (table.Rows.Count == 0)
            {
                return(null);
            }

            //criar variaveis necessarias par ao objeto de utilizador
            denominacao = table.Rows[0].Field <string>("denominacao");

            //Criar novo objeto de Utilizador
            estado = new EstadoAvaria(id, denominacao);
            estados.Add(estado);

            return(estado);
        }
Exemple #2
0
        public static Avaria Novo(string descricao, string imagem, Contrato contrato, Utilizador utilizador, TipoAvaria tipo, EstadoAvaria estado)
        {
            int          id = 0;
            int          rows;
            Avaria       novoAvaria;
            DBConnection conn = new DBConnection();
            DataTable    dt;

            //Inserir morada na base de dados
            rows = conn.NonQuery("INSERT INTO avaria (descricao, utilizador_id, imagem, contrato_id, tipo_avaria_id, estado_id) VALUES (@0, @1, @2, @3, @4, @5)", descricao, utilizador.Id, contrato.Id, tipo.Id, estado.Id);

            dt = conn.Query("SELECT * FROM utilizador WHERE codigo = @0 AND utilizador_id = @1 AND contrato_id = @2 AND tipo_avaria_id = @3 AND estado_id = @4 ORDER BY id DESC LIMIT 1", utilizador.Id, contrato.Id, tipo.Id, estado.Id);

            id = dt.Rows[dt.Rows.Count - 1].Field <int>("id");

            novoAvaria = new Avaria(id, tipo, descricao, imagem, estado);
            avarias.Add(novoAvaria);

            return(novoAvaria);
        }