栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

java获得每个公司的平均薪水并传递给JSP

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

java获得每个公司的平均薪水并传递给JSP

出于性能原因,应将平均计算委托给数据库。 避免

CompanyDAO.getAll()
自己计算平均值。这样做可能会导致N +
1个选择问题,你当
LAZY
装车选择。

使用此JPQL查询在数据库中进行平均值计算:

SELECt e.company, AVG(e.salary) FROM Employee e GROUP BY e.company

更准确地说,更改

CompanyDAO.java
如下:

public static List<Company> getAll() {    EntityManager em = GestionFactory.factory.createEntityManager();    Query q = em.createQuery("SELECt e.company, AVG(e.salary) FROM Employee e GROUP BY e.company");    // each list entry contains a tuple (company, avgSalary)    List<Object[]> results = q.getResultList();    List<Company> companiesList = new linkedList<>();    for (Object[] entry : results) {        Company company = (Company) entry[0]; // contains "e.company"        Double avgSalary = (Double) entry[1]; // contains "AVG(e.salary)"        company.setAverageSalary(avgSalary);        companiesList.add(company);    }    return companiesList;}

为此,请扩展您的

Company.java
实体类型,如下所示:

@Entitypublic class Company implements Serializable {    // ...    @Transient    private double averageSalary;    public void setAverageSalary(double averageSalary) {        this.averageSalary = averageSalary;    }    public double getAverageSalary() {        return averageSalary;    }}

在您的JSP中,只需使用

<%=company.getAverageSalary()%>

请考虑这是一个需要进一步完善的解决方案草案。 该解决方案适用于Eclipselink。对于Hibernate,您宁愿使用

@Formula
注释。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/633473.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号