今天在別人的代碼基礎上實現新需求,看到對於mybatis查詢結果的判斷不是很正確,如果查詢結果為空就會異常,不知道大家有沒有這樣的疑惑:mybatis中resultType有多種返回類型,對於每種不同類型,查詢結果為空時dao介面的返回值是一樣的嗎?接下來我就總結一下常見的幾種情況。 第一種:res ...
今天在別人的代碼基礎上實現新需求,看到對於mybatis查詢結果的判斷不是很正確,如果查詢結果為空就會異常,不知道大家有沒有這樣的疑惑:mybatis中resultType有多種返回類型,對於每種不同類型,查詢結果為空時dao介面的返回值是一樣的嗎?接下來我就總結一下常見的幾種情況。
第一種:resultType為基本類型,如string(在此暫且把string歸納為基本類型)
如果select的結果為空,則dao介面返回結果為null
第二種,resultType為基本類型,如int
後臺報異常:
org.apache.ibatis.binding.BindingException: Mapper method 'com.fkit.dao.xxDao.getUserById attempted to return null from a method with a primitive return type (int).
解釋:查詢結果為null,試圖返回null但是方法定義的返回值是int,null轉為int時報錯
解決辦法:修改select的返回值為String
第三種 resultType為類為map ,如map、hashmap
dao層介面返回值為null
第四種 resultType 為list ,如list
dao層介面返回值為[],即空集合。
註意:此時判斷查詢是否為空就不能用null做判斷
第五種 resultType 為類 ,如com.fkit.pojo.User
dao層介面返回值null