关于return null 的疑惑

G.Jagger 2018-06-01 11:13:31
第一段代码:
public Page<Record> getLogPages(String meter_id, Integer emi, Integer lack, Integer low, Integer close, 
String stat, Integer page, Integer limit) throws Exception {
String tbName = "data_civils_";
if(StringUtils.isNotEmpty(stat))
tbName += stat.replace("-", "").substring(0,6);
else
tbName += DateFormatUtils.format(new Date(), "yyyyMM");
String tb = Db.queryStr("select table_name from information_schema.TABLES WHERE table_name = ?", tbName);
if(StringUtils.isEmpty(tb))
return null;
else{
String filter = getFilter(emi, lack, low, close, null, null);
if(StringUtils.isNotEmpty(meter_id))
filter += " and t.device_id = '" + meter_id + "'";
if(StringUtils.isNotEmpty(stat))
filter += " and t.stat_date = '" + stat + "'";
String sql = "select count(1) from " + tbName + " t where 1=1";
Long count = Db.queryLong(sql + filter);
sql = "select t.stat_date, t.reading, t.voltage, t.surplus, t.balance, t.nouse, t.nosub, t.is_emi, t.is_lack, t.is_low, t.is_close, t.update_time,"
+ " case when t.is_emi = 1 then 'red' else 'green' end color1, case when t.is_lack = 1 then 'red' else 'green' end color2,"
+ " case when t.is_low = 1 then 'red' else 'green' end color3, case when t.is_close = 1 then 'red' else 'green' end color4"
+ " from " + tbName + " t where 1=1" + filter + " order by t.stat_date desc limit ?,?";
return new Page<Record>(page, limit, count, Db.find(sql, (page - 1) * limit, limit));
}
}


第二段代码:
public Page<Record> getLogPages(Integer id, String stat, Integer page, Integer limit) throws Exception{
String tbName = "data_cards_";
if(StringUtils.isNotEmpty(stat))
tbName += stat.replace("-", "").substring(0,6);
else
tbName += DateFormatUtils.format(new Date(), "yyyyMM");
String tb = Db.queryStr("select table_name from information_schema.TABLES where table_name = ?", tbName);
if(StringUtils.isEmpty(tb))
return null;
else{
String filter = "";
if(StringUtils.isNotBlank(stat))
filter += " and stat_date = '" + stat.trim() + "'";
if(id != null)
filter += " and device_id = " + id;
String sql = "select count(1) from tank." + tbName + " where 1=1";
Long count = Db.queryLong(sql + filter);
sql = "select * from tank." + tbName + " where 1=1 " + filter + " order by update_time desc limit ?,?";
return new Page<Record>(page, limit, count, Db.find(sql, (page - 1) * limit, limit));
}
}

跟踪了一下发现第一段代码 return null 返回的是null,而第二段代码return null 返回的是一个page对象,这是什么原因?
...全文
1210 10 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
xwn_2016 2018-06-01
  • 打赏
  • 举报
回复
还有一种可能,一个方法你用对象去接收了,而另一个没有
QWERT4745 2018-06-01
  • 打赏
  • 举报
回复
在return new Page打断点
G.Jagger 2018-06-01
  • 打赏
  • 举报
回复
引用 1 楼 xwn_2016 的回复:
确认都是return null这行返回的么,还是下边return 时 返回的是没有查到结果的对象
恩,都是return null 这行返回的,我打断点跟踪的
xwn_2016 2018-06-01
  • 打赏
  • 举报
回复
确认都是return null这行返回的么,还是下边return 时 返回的是没有查到结果的对象
〇ne丶 2018-06-01
  • 打赏
  • 举报
回复
一个tb是空 一个不是,tbName不一样
KeepSayingNo 2018-06-01
  • 打赏
  • 举报
回复
第1和2段代码从第10行之前都是一样啊,你不行,就只保留10行以前的代码跑跑,肯定都是为null
逍遥哥哥吖 2018-06-01
  • 打赏
  • 举报
回复
把两个SQL语句打出来,放数据库中查询一下,看看结果
nayi_224 2018-06-01
  • 打赏
  • 举报
回复
你看错了,不然就把上层调用的代码发出来吧
诺丽果 2018-06-01
  • 打赏
  • 举报
回复
你确定都是 if(StringUtils.isEmpty(tb))这句下面的 return null;返回的?这两段代码中tb都是空的吗?

81,122

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧