C# HQL在select NHIBERNATE中返回双精度值
我有这个查询,它应该返回double(即数据库中的C# HQL在select NHIBERNATE中返回双精度值,c#,nhibernate,asp.net-mvc-5,C#,Nhibernate,Asp.net Mvc 5,我有这个查询,它应该返回double(即数据库中的Decimal(10,2)): 公共产品搜索价格(字符串nmproduct) { string hql=“从产品x中选择x.custo,其中x.nmproduct=?”; IQuery=session.CreateQuery(hql); query.SetParameter(0,nmproduct); 返回query.UniqueResult(); } 我想在数据库中得到价格 例外情况是: 无法将“System.Decimal”类型的对象强制转
Decimal(10,2)
):
公共产品搜索价格(字符串nmproduct)
{
string hql=“从产品x中选择x.custo,其中x.nmproduct=?”;
IQuery=session.CreateQuery(hql);
query.SetParameter(0,nmproduct);
返回query.UniqueResult();
}
我想在数据库中得到价格
例外情况是:
无法将“System.Decimal”类型的对象强制转换为“Administrative.Models.products”类型
如果要将十进制值转换为实体,则需要使用:
query.UniqueResult<decimal>()
query.uniquerysult()
当您表示货币时,您需要使用
decimal
而不是double
,为了不失去准确性,请阅读。如果您要将十进制值转换为您的实体,您需要使用:
query.UniqueResult<decimal>()
query.uniquerysult()
当您表示货币时,您需要使用
decimal
而不是double
以避免丢失准确性,请阅读。谢谢,它解决了问题。只需要换成十进制public decimal SearchPrice(string nmproduct){string hql=“从产品x中选择x.custo,其中x.nmproduct=?”;IQuery query=session.CreateQuery(hql);query.SetParameter(0,nmproduct);return query.UniqueResult();}
谢谢,它解决了这个问题。只需要换成十进制public decimal SearchPrice(string nmproduct){string hql=“从产品x中选择x.custo,其中x.nmproduct=?”;IQuery query=session.CreateQuery(hql);query.SetParameter(0,nmproduct);return query.UniqueResult();}