有没有办法推广petapoco选择查询

时间:2017-04-12 09:49:20

标签: c# petapoco

我正在尝试使用PetaPoco ORM从MySQL表中获取数据。以下是仅获取一条记录的示例代码:

public void ShowEmployerDetails()
        {
            using (var db = new PetaPoco.Database ("mysql_mydb")) {
                try {
                    var employers = db.Query <Employers> ("SELECT * FROM Employer WHERE id = 123456789");
                    foreach(var e in employers) {
                        return e.EmployerName;
                    }
                } catch (Exception ex) {
                    log.Error (ex.Message);
                }
            }
        }

需要在db.Query函数中传递实体类型。对于每个DB表,我们需要定义实体。在这种情况下,实体类型为<Employers>,代码为:

public class Employers
    {
        public int id { get; set; }
        public string EmployerName { get; set; }
    }

有没有办法可以概括上面的选择查询呢?例如,我打算使用单个查询获取输出,如:

PetaPocoQueryEntities <Employers>.GetDataFromEntities ("SELECT * FROM Employer WHERE id = 123456789", "EmployerName");

查询可能类似于下面的内容,其中实体类型可以作为泛型类型T传递,并想知道是否有某种方式提供列名并动态获取列值:

public static class PetaPocoQueryEntities <T> 
    {
        public static readonly ILog log = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);

        public static T GetDataFromEntity (string sqlQuery, string colName )
        {
            using (var db = new PetaPoco.Database ("mysql_mydb")) {
                try {
                    var entityResults = db.Query<T> (sqlQuery);
                    foreach (var result in entityResults) {
                        log.Info(colName + " value is " + result.colName);
                    }
                } catch (Exception ex) {
                    log.Error (ex.Message);
                }
                return colName;
            }
        }
}

请帮忙。

1 个答案:

答案 0 :(得分:1)

  

需要在db.Query函数

中传递实体类型

简短回答 - 是的。 PetaPoco使用此信息将查询中的数据正确映射回实体

  

有没有办法可以概括上面的选择查询呢?例如,我打算使用单个查询获取输出,如:

是的,你可以解决这个问题。 This integration test should get you started.