Java开发中那些不容忽略的小问题

Wesley13
• 阅读 489

写公众号说实话挺久了,也因此认识了很多的朋友,咨询什么的都有,总之,或多或少的帮助到过一些人。最近想了好久,我往后应该写一些什么类型的文章?

1、偏理论的?

感觉在一篇文章里面去概述一些比较复杂的理论,说不说的完暂且不说,作为一个读者大部分肯定是没有耐心看下去的,而且看完吸收的也不会很多,这种东西还是得通过啃书的方式可能会更好。

2、偏代码层次的?

之前也写过几篇文章里面代码很多,但是其实很少有人认认真真的研究过那些代码,也没有验证过,因为大家有可能是在上班的路上,或者吃饭期间再看,所以只是一眼看过。

那么我就在想,我们可以分享一些什么东西,可以让大家在零碎的时间中学的可以落实的东西,我觉得这些东西得从涉及面小、落实快等方面入手,看了某个东西之后,可以快速的消化,并且可以落实到代码中的,我觉得才是最好的。

废话不多说,几天分享几个平时开发中遇到的小问题;

一、Java中提供的空集合到底有用没有?

这是我看了几篇文章,然后结合自己项目中的代码后所理解的,这个东西首先肯定是有用的。我们来看一段代码。

Java开发中那些不容忽略的小问题

现在的接口基本都是基于RESTful风格的,如果将这个方法提供给别人,那么肯定会存在一个问题,可能会出现空指针异常,(真是经历)前端要去集合中取数据,如果前端没有做任何的非空判断,直接从集合中取,那么当返回null的时候,势必造成空指针异常。

所以查询不到数据的时候,我们应当判断该集合是不是为null,如果为null我们应该返回一个空的集合,如果我们直接new一个ArrayList其实是非常浪费资源的,这个时候Java中提供的Collections.emptyList(); 就排上用场了,它创建的是一个不允许添加、删除、修改的空集合;

修改后的代码

Java开发中那些不容忽略的小问题

二、Mybatis批量修改语句

这是我今天早上碰到的一个问题,我们之前的批量修改是将一批数据的某个字段改为同一个值,比如批量逻辑删除,其实就是把需要删除的数据的status值改为0或者其他值,但是我们这个是这样的,编辑了好几条数据信息,然后每个数据信息的值是不一样的,为了减少数据库的连接次数,我们直接通过mybatis动态sql进行修改;

代码如下:

Java开发中那些不容忽略的小问题

但从语句上看,确实毫无问题,但是在我调试的过程中(基于SpringBoot的项目),真的是白板艰难,一直报错。一直说语法存在问题,请查询手册。

报错信息:

### Error updating database. Cause: java.sql.SQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'update mall_product_specification

问题原因:
这是因为mysql不支持此方式的批量修改操作,所以当我们修改批量数据的时候,就会报这个错,如果修改的是单条数据,不会出现该错误。

解决方法:

在数据库的连接后面配置参数 &allowMultiQueries=true 即可

Java开发中那些不容忽略的小问题

推荐阅读

**强烈推荐,IDEA开发必备的4款插件(文末送书)
**

SpringBoot整合easyexcel实现Excel的导出

漫画 | 外行对程序员误会有多深!

Java开发中那些不容忽略的小问题

本文分享自微信公众号 - 一个程序员的成长(xiaozaibuluo)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
待兔 待兔
2个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Stella981 Stella981
2年前
Android So动态加载 优雅实现与原理分析
背景:漫品Android客户端集成适配转换功能(基于目标识别(So库35M)和人脸识别库(5M)),导致apk体积50M左右,为优化客户端体验,决定实现So文件动态加载.!(https://oscimg.oschina.net/oscnet/00d1ff90e4b34869664fef59e3ec3fdd20b.png)点击上方“蓝字”关注我
Easter79 Easter79
2年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
2年前
Docker 部署SpringBoot项目不香吗?
  公众号改版后文章乱序推荐,希望你可以点击上方“Java进阶架构师”,点击右上角,将我们设为★“星标”!这样才不会错过每日进阶架构文章呀。  !(http://dingyue.ws.126.net/2020/0920/b00fbfc7j00qgy5xy002kd200qo00hsg00it00cj.jpg)  2
Stella981 Stella981
2年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
2年前
35岁是技术人的天花板吗?
35岁是技术人的天花板吗?我非常不认同“35岁现象”,人类没有那么脆弱,人类的智力不会说是35岁之后就停止发展,更不是说35岁之后就没有机会了。马云35岁还在教书,任正非35岁还在工厂上班。为什么技术人员到35岁就应该退役了呢?所以35岁根本就不是一个问题,我今年已经37岁了,我发现我才刚刚找到自己的节奏,刚刚上路。
京东云开发者 京东云开发者
10个月前
Java服务总在半夜挂,背后的真相竟然是... | 京东云技术团队
最近有用户反馈测试环境Java服务总在凌晨00:00左右挂掉,用户反馈Java服务没有定时任务,也没有流量突增的情况,Jvm配置也合理,莫名其妙就挂了