写Java和SQL语句的遇到各种问题及解决方法(更新中)

1.在Navicat写好的SQL语句且有效,但是复制到IDEA里使用时却报错(带参)

错误信息:

将参数成功传入但是在运行时SQL语句的参数那里却显示问号

解决方法:将SQL语句#{channel}外面的单引号去掉即可成功获取数据

2.在用DateUtil.format转化成String类型的时候,yyyy-MMyyyy-mm是不一样的

String time=DateUtil.format(DateUtil.offsetMonth(new Date(),-2),"yyyy-MM")+"-01";

效果是:

String time=DateUtil.format(DateUtil.offsetMonth(new Date(),-2),"yyyy-mm")+"-01";

效果是:(但是好像试了几次效果都不一样)

3.

for (Map<String, String> map : LMSS) {

if(StrUtil.isNotBlank(map.get("productDetail"))){

JSONArray jsonArray = new JSONArray(map.get("productDetail"));

因为SQL语句多表查询获取的是两个表的部分字段,因此用了Map<String,String>这种键值对列表来获取,由于productDetail字段又是由多个JSONObject构成的,所以用JSONArray来接收,但是由于我在测试的时候有条数据的productDetail字段是空,导致JSONArray jsonArray = new JSONArray(map.get("productDetail"));报错

因为其不含[],不符合JSONArray的格式,所以报错。

if(StrUtil.isNotBlank(map.get("productDetail"))){

因此我在获取之前加了一个if语句来防止报错

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值