欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mybatis?傳入null值的解決方案

 更新時間:2022年03月10日 10:36:04   作者:A雄  
這篇文章主要介紹了mybatis?傳入null值的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

mybatis 傳入null值解決

前端傳入兩個值,如果其中一個為null時,很多時候我們都很困惑,明明傳入的是null,為啥mybatis 的xml文件中的if條件判斷無效?

public String getPersonInfo(@PathParam("Name") String Name, @PathParam("IDCard") String IDCard)

dao層

public List<Map> getPersonInfo(@Param("name") String name, @Param("idcard") String idcard);

xml文件內(nèi)容

<if test="name == null or name == '0'.toString()">?
? ? <![CDATA[ and (b.identity_id = #{idcard,javaType=String,jdbcType=VARCHAR})
? ? group by name,id_card,birthTime,sex ?]]>?
</if>

每次執(zhí)行都是失敗的,網(wǎng)上很多都說要在dao層添加@param注解和xml文件內(nèi)容中要加入jdbcType類型就能解決,最后還是沒解決

其實還有一個點忽略了,就是傳入時的null值其實是個字符串null,根本就不是null,它是個字符串null

? ? ? ? if (Name == null || "null".equalsIgnoreCase(Name)) {
? ? ? ? ? ? Name = null;
? ? ? ? }
? ? ? ? if (IDCard == null || "null".equalsIgnoreCase(IDCard)) {
? ? ? ? ? ? IDCard = null;
? ? ? ? }

問題解決!

mybatis 注入老是為null

今天遇到個很弱智的問題,以此記錄!時刻提醒自己

    public int delExhibion(List<String> ids){
        Integer result = null;
        ExhibitionManager exhibitionManager = new ExhibitionManager();
        for (String id : ids){
            exhibitionManager.setId(id);
            exhibitionManager.setDelFlag("1");
             result += exhibitionManagerMapper.delete(id);
        }
        return result;
    }

發(fā)現(xiàn)老是執(zhí)行 delete 的時候 ,老是報 空指針異常

然后嘗試使用:  @Param  給參數(shù)加上命令     

int delete(@Param("id") String id); ?

結(jié)果還是不行,

然后在嘗試使用:對象傳參,這樣總該注入進去了吧 

int delete(Object dx);

結(jié)果還是不行,

然后在嘗試使用:Mybatis 單個參數(shù)動態(tài)語句引用:

是當我們的參數(shù)為String時,在sql語句中#{id} 會去我們傳進來的參數(shù)調(diào)getId()方法獲取參數(shù),很明顯,String沒有對應(yīng)的方法,所以報錯了,那我們這里要如何引用id呢,需要采用下面的寫法:

<delete id="delete" parameterType="java.lang.String" > ?
? ? ? ? ?SELECT * FROM table
? ? ? ? ?<where> ?
? ? ? ? ? ? ? ? ? ?<if test="_parameter != null"> ?
? ? ? ? ? ? ? ? ? ? ? ? ? ? AND id= #{id} ?
? ? ? ? ? ? ? ? ? ?</if> ?
? ? ? ? ?</where> ?
</select>

單Mybatis傳參為單個參數(shù)時,在sql語句中需要使用  _parameter 來引用這個參數(shù)

結(jié)果還是不行。  

終于過了一會兒,看代碼時突然頓悟

? ? public int delExhibion(List<String> ids){
? ? ? ? Integer result = null;
? ? ? ? for (String id : ids){
? ? ? ? ? ? ?result += exhibitionManagerMapper.delete(id);
? ? ? ? }
? ? ? ? return result;
? ? }

Integer  result  我給他設(shè)置默認值  為null,   并且還讓  reuslt  這個對象   result +=   

加等于在執(zhí)行數(shù)據(jù)庫操作返回結(jié)果時 用 result 去接收。 這不就一定是空指針了嗎。

我給 Integer result = 0;  設(shè)置個默認值為0   那也不會出現(xiàn)這種情況!

或者 result =   給result  初始化賦值     也不會報  空指針異常!  不過這樣做在我的業(yè)務(wù)中是不對的哦。  只是不會報錯. 但是獲取不到我想要的執(zhí)行成功條數(shù)

Integer result = null;
result = ?exhibitionManagerMapper.delete(id);

真的是被自己氣到了。以此記錄!時刻提醒自己   

?public int delExhibion(List<String> ids){
? ? ? ? Integer result = 0;
? ? ? ? for (String id : ids){
? ? ? ? ? ? ?result += exhibitionManagerMapper.delete(id);
? ? ? ? }
? ? ? ? return result;
? ? }

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論