展开全部
1、使用Map jdbcTemplate.queryForMap查询,其返回结果e5a48de588b63231313335323631343130323136353331333431356638必须有且只有1个map值,否则会抛出异常。若抛出异常,则肯定不会得到返回值。
例如“控制台提示错误Incorrect result size: expected 1, actual 0”。
问题原因参考(1)字符串的Jdbctemplate查询:EmptyResultDataAccessException:结果大小不正确:预期1,实际0网页链接
问题原因参考(2)JdbcTemplate queryForObject结果大小不正确:预期为1,实际为0网页链接
2、推荐使用jdbcTemplate.query或List> jdbcTemplate.queryForList查询。/**
*
* @Title: querySpxxMap_dbBySsflbm
* @Description: TODO(根据税收分类编码、企业id,联查商品信息表、税收分类编码表的,商品id+商品名称+规格型号+计量单位+税率+税收分类编码)
* @param ssflbm
* @param qyid
* @return 设定文件
* @return Map 返回类型
* @throws
*/
public List> querySpxxMap_dbBySsflbm(String ssflbm, String qyid) {
String sql="select spxx.id,spxx.spmc,spxx.ggxh ,spxx.jldw,ss.slv ,ss.hbbm ssflbm "
+ "from t_jc_ssflbm ss "
+ "left join t_qy_spxx spxx on spxx.ssflbm=ss.hbbm "
+ "where ss.hbbm=? and spxx.qyid=?";
//queryForList 参数写法1
List conditionList = new ArrayList();
conditionList.add(ssflbm);
conditionList.add(qyid);
List> list1=jdbcTemplate.queryForList(sql,conditionList.toArray());
//queryForList 参数写法2
List> list2=jdbcTemplate.queryForList(sql,new Object[] {ssflbm,qyid});
return list1;
}