解決MyBatis返回結(jié)果類型為Boolean的問題
問題描述:
在使用MyBatis時(shí),有時(shí)需要檢查某個(gè)記錄是否存在數(shù)據(jù)庫中,然后根據(jù)其返回的布爾值true or false,來進(jìn)行邏輯判斷。那怎么做呢?
解決方案:
如檢測某個(gè)手機(jī)號(hào)是否被注冊(cè)過:
<select parameterType='java.lang.String' resultType='java.lang.Boolean'> <![CDATA[ select count(id) from ec_user where PHONE = #{phone, jdbcType=VARCHAR}]]> </select>
注意事項(xiàng):
Mybatis是根據(jù)查詢到的記錄數(shù)進(jìn)行轉(zhuǎn)換的(1表示為true,0表示為false) 。然而,如果查詢到多條記錄(大于1),則返回的布爾值為false。
這時(shí)候,我們需要將返回來的記錄數(shù)進(jìn)行判斷,就可以確保該記錄在數(shù)據(jù)庫中的唯一性了。
補(bǔ)充知識(shí):Mybatis Mysql布爾類型處理
針對(duì)mysql數(shù)據(jù)庫作如下測試,
如果數(shù)據(jù)庫存的為非0數(shù)字,轉(zhuǎn)換為true,否則為false
如果javaType的Boolean類型值為true,存到數(shù)據(jù)庫數(shù)字為1,false則為0
以上這篇解決MyBatis返回結(jié)果類型為Boolean的問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. MySQL Community Server 5.1.492. MYSQL數(shù)據(jù)庫存文本轉(zhuǎn)存數(shù)據(jù)庫問題3. 快速刪除ORACLE重復(fù)記錄4. MySQL中 concat函數(shù)的使用5. 數(shù)據(jù)庫相關(guān)的幾個(gè)技能:ACCESS轉(zhuǎn)SQL6. Oracle災(zāi)難防護(hù)的關(guān)鍵技術(shù)7. Mysql入門系列:MYSQL創(chuàng)建、刪除、索引和更改表8. MySql遠(yuǎn)程連接的實(shí)現(xiàn)方法9. Delphi中的Access技巧集10. Windows下不能啟動(dòng)mysql服務(wù)--錯(cuò)誤總結(jié)

網(wǎng)公網(wǎng)安備