gpt4 book ai didi

c# - NHibernate CreateSQLQuery

转载 作者:可可西里 更新时间:2023-11-01 08:04:09 26 4
gpt4 key购买 nike

我正在尝试使用 NH CreateSQLQuery 方法获取一些数据,例如

IList<Logistic> LCollection = sess.CreateSQLQuery(@"select * from some_schema.logistic")
.SetResultTransformer(Transformers.AliasToBean(typeof(Logistic)))
.List<Logistic>();

物流类是

public class Logistic
{
public virtual long? l_id { get; set; }
public virtual long? carrier_id { get; set; }
...
}

映射

public class LogisticMap : ClassMap<Logistic>
{
public LogisticMap()
{
Table("some_chema.logistic");
Id(x => x.l_id).GeneratedBy.Sequence("some_chema.logistic_sq");
Map(x => x.carrier_id);
...
}
}

但是我有错误

The type System.Decimal can not be assigned to a property of type System.Nullable`1[System.Int64] setter of MyNamespase.Logistic.l_id

知道哪里出了问题吗?

最佳答案

AliasToBean 转换器在您想要检索轻量级 DTO 而不是实体时使用。 (例如,如果您有一个概览屏幕,它只显示每个实体的一些基本信息,那么最好使用 DTO 并在使用 AliasToBean 转换器的 NHibernate 中创建一个查询,以便 NH 知道它不应该检索完整的实体)。

如果您想使用 SQL 查询检索实体,您必须这样做:

var query = sess.CreateSQLQuery(@"select {l.*} from some_schema.logistic as l");

query.AddEntity ("l", typeof(Logistic));

return query.List<Logistic>();

但是,我想知道您为什么要在这种情况下使用 native SQL 查询?为什么不使用 HQLICriteriaQueryOver

关于c# - NHibernate CreateSQLQuery,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12513191/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com