首页 > 解决方案 > 有什么简单的方法可以从 datareader 填充列表模型吗?

问题描述

我正在通过 OracleDataReader 从表中获取数据。我有这张桌子的模型。

员工模型

 public class Employee
    {
        public int ID { get; set; }
        public int SIRKETID { get; set; }
        public string NAME{ get; set; }
        public string SURNAME{ get; set; }
        public string DEPARTMENT{ get; set; }
        public string STATUS{ get; set; }
    }

控制器

 public JsonResult getEmployee()
    {
....
                string sql = @"select * from Employee";
                OracleCommand command = new OracleCommand(sql, connection);
                OracleDataReader reader = command.ExecuteReader();

                while (reader.Read())
                {
                    var employee = new Employee();
                    Employee.ID = Convert.ToInt32(reader["ID"]);
                    Employee.SIRKETID = Convert.ToInt32(reader["SIRKETID "]);
                    Employee.NAME = reader["NAME"].ToString();
                    Employee.SURNAME = reader["SURNAME"].ToString();
                    Employee.DEPARTMENT = reader["DEPARTMENT"].ToString();
                    Employee.STATUS = reader["STATUS"].ToString();

                    model.Add(Employee);
                }
....
                return Json(new { data = model});
    }

这很好用,但我不想一一映射列。我有 100 列。而且我不知道某些表中有多少列

有什么简单的方法可以将模型返回为 json

标签: c#oraclemodelautomapperdatareader

解决方案


您可以使用像Dapper这样的第三方库,这是一个用于 .Net 的简单对象映射器。

您可以在下面查看基本用法示例:

public class Dog
{
    public string Name { get; set; }
    public float? Weight { get; set; }    
}

var dog = connection.Query<Dog>("SOME QUERY", new { Name = "DOGNAME" });

推荐阅读