2017年2月28日笔记与反省

2017年2月28日 14:31:23

上午做的事情就是把数据库的数据重新评论一下,使得如果《老板好》选中数据库中插入一个数为1,没有选中则插入数为0,《结钱快》、《工作轻松》两个选项给出类似的记录,便于数据的统计。

快接近中午的时候其实就已经写出了把数据从数据库查询出来的SQL语句,

SELECT COUNT(*) FROM (SELECT t.anonymous_flag,t.attitude_score,t.comment_content,t.comment_summary ,t.comment_summary_boss,t.apply_id,m.position_id FROM user_apply_comment t,user_job_apply m WHERE t.apply_id=m.apply_id) n WHERE n.position_id=4920 AND n.comment_summary_boss=1

 

其实HQL语句只需要

select count(*) from UserApplyComment where state=1 and apply.positionId=4920  and commentSummaryBoss=1 

 

最后一直报错

 Servlet.service() for servlet [default] in context with path [] threw exception [java.lang.IndexOutOfBoundsException: Remember that ordinal parameters are 1-based!] with root cause

java.lang.IndexOutOfBoundsException: Remember that ordinal parameters are 1-based!

 原来是超出范围,后边看到Remember that ordinal parameters are 1-based!显示缺少一个占位符。

public Integer  getAboutCommentBossSql(Integer positionId){

StringBuffer hql = new StringBuffer("select count(*) from UserApplyComment uac where state=")

   .append(ConstantsUtil.DB_EFFECTIVE)

.append(" and uac.apply.positionId= ?")

.append("  and uac.commentSummaryBoss=1 ");

Object obj = findObjByHql(hql.toString(), positionId);

return obj == null ? 0 : IntegerUtil.parseInt(obj);

}

同样的方法把其他两个也弄好了,可以放到前端页面显示。

 

问题来了,之前的前段工程师没有设置那个位置来显示条数,我按照经理的临时主意加上去,结果页面乱套了,显示起来好难看。

其实是百分条并列的位置加上

<div class="cell-fixed" style="padding-left:5px;">${aboutBossCount}条</div>

这样就不会影响整个布局了。(2017年2月28日 16:59:01实在前端工程师吴老师的帮助下搞定的)

2017年2月28日 15:04:50

现在是各个字段的条数可以对比,我的思路是a>b>c,那么a为100%,b为b/a%,c为c/a%.,问题来了在前端页面和后端java代码是如何判断呢。

 

 

我最初的想法是服务器端把所有的百分数先搞定再传到前端页面,在这过程中犯的错有以下:

1.处理条数使用的工具不对是IntegerUtil.parseInt(positionId)而不是StringUtil.str2Int(positionId),还有就是处理double类型也有相应的工具封装好的

2.在做除法的时候,两个整数类型相除,除不断会是零,2/3的结果是0,正常的相除先得把他们转化为double类型

这两个原因导致老是得不出结果。

3.由于在服务端处理百分数使得代码很多,其实在JSP中有专门的标签可以处理百分数的

<fmt:formatNumber>标签

<fmt:formatNumber type="percent" 
            maxIntegerDigits="3" value="${balance}" />

让我受益匪浅,谢谢陈哥的指导,也怪自己学艺不精。当时陈哥建议我有时间好好看JSP的标签库的知识,而我学得不够,相当可耻的事。

这是在前端显示就可以了

       <div class="weui_progress_inner_bar js_progress bg-blue" style="width: <fmt:formatNumber type="percent" 

            maxIntegerDigits="3" value="${aboutMoneyCount/max}" />;"></div>

其中aboutMoneyCount和max是由后端传来,这样就可以简单的处理好百分比了(主要是逻辑简化和代码量减少)。

(笔记于2017年2月28日 18:03:43)

转载于:https://my.oschina.net/3ThinkForDo/blog/847968

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值