org.hibernate.criterion.Example 类

ResourceAssign raExample = new ResourceAssign();
raExample.TargetEffortEstimation.Id = effortestimationId;
raExample.TargetFiscalYear.Id = fiscalYearId;
raExample.TargetMemberResource.ID = memberResourceId;

IList<ResourceAssign> ra = NHibernateSessionManager.Instance.GetSession().CreateCriteria(typeof(ResourceAssign), "ra")
.Add(Example.Create(raExample))
.List<ResourceAssign>();

------------------------------------------------------------------
//ResourceAssign raExample = new ResourceAssign();
//raExample.TargetEffortEstimation = EffortEstimationDao.GetById(effortEstimationId, false);
//raExample.TargetFiscalYear =FiscalYearDao.GetById(fiscalYearId, false);

ICriteria query = NHibernateSessionManager.Instance.GetSession().CreateCriteria(typeof(ResourceAssign), "ra")
// .Add(Example.Create(raExample))
.SetProjection(Projections.ProjectionList().Add(Projections.Sum("Month10"))
.Add(Projections.Sum("Month11"))
.Add(Projections.Sum("Month12"))
.Add(Projections.Sum("Month1"))
.Add(Projections.Sum("Month2"))
.Add(Projections.Sum("Month3"))
.Add(Projections.Sum("Month4"))
.Add(Projections.Sum("Month5"))
.Add(Projections.Sum("Month6"))
.Add(Projections.Sum("Month7"))
.Add(Projections.Sum("Month8"))
.Add(Projections.Sum("Month9")));

object[] os = (object[])(query.UniqueResult() ?? new float[12]);
float[] f = new float[12] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
for (int j = 0; j < 12; j++)
{
f[j] = (float)Convert.ToDouble(os[j] ?? 0);
}

return f;

----------------------------------------------------------------------

StringBuilder sbSQL = new StringBuilder("SELECT ");
sbSQL.Append("SUM(MANMONTH_10) AS s1, SUM(MANMONTH_11) AS s2, ");
sbSQL.Append("SUM(MANMONTH_12) AS s3, SUM(MANMONTH_01) AS s4, ");
sbSQL.Append("SUM(MANMONTH_02) AS s5, SUM(MANMONTH_03) AS s6, ");
sbSQL.Append("SUM(MANMONTH_04) AS s7, SUM(MANMONTH_05) AS s8, ");
sbSQL.Append("SUM(MANMONTH_06) AS s9, SUM(MANMONTH_07) AS s10, ");
sbSQL.Append("SUM(MANMONTH_08) AS s11, SUM(MANMONTH_09) AS s12");

sbSQL.Append(" FROM RESOURCE_ASSIGN INNER JOIN MEMBERRESOURCE ON RESOURCE_ASSIGN.FK_MEMBERRESOURCE_ID = MEMBERRESOURCE.MEMBERRESOURCE_ID");
sbSQL.Append(" INNER JOIN TEAM ON MEMBERRESOURCE.FK_TEAM_ID = TEAM.TEAM_ID");
sbSQL.Append(" WHERE (RESOURCE_ASSIGN.FK_FISCAL_YEAR_ID =:fyid) AND (TEAM.FK_DIVISION_ID =:depid)");

IQuery sqlQuery = NHibernateSessionManager.Instance.GetSession().CreateSQLQuery(sbSQL.ToString())
.AddScalar("s1", NHibernateUtil.Single)
.AddScalar("s2", NHibernateUtil.Single)
.AddScalar("s3", NHibernateUtil.Single)
.AddScalar("s4", NHibernateUtil.Single)
.AddScalar("s5", NHibernateUtil.Single)
.AddScalar("s6", NHibernateUtil.Single)
.AddScalar("s7", NHibernateUtil.Single)
.AddScalar("s8", NHibernateUtil.Single)
.AddScalar("s9", NHibernateUtil.Single)
.AddScalar("s10", NHibernateUtil.Single)
.AddScalar("s11", NHibernateUtil.Single)
.AddScalar("s12", NHibernateUtil.Single)
.SetInt64("fyid", fiscalYearId)
.SetInt64("depid", departmentId);

object[] os = (object[])(sqlQuery.UniqueResult() ?? new float[12]);

float[] f = new float[12] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };

for (int j = 0; j < 12; j++)
{
f[j] = (float)Convert.ToDouble(os[j] ?? 0);
}

return f;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值