亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

創建條件構造器傳入實體對象時,沒有設置主鍵值,查詢SQL日志顯示主鍵值為0

/**
?*?創建條件構造器時傳入實體對象
?*/
@Test
public?void?selectByWrapperEntity(){
????User?whereUser?=?new?User();
????whereUser.setName("Jack");
????whereUser.setAge(20);

????QueryWrapper<User>?queryWrapper?=?new?QueryWrapper<User>(whereUser);

????List<User>?userList?=?userMapper.selectList(queryWrapper);
????userList.forEach(System.out::println);
}


##### SQL日志執行如下

==>? Preparing: SELECT id,name,age,email FROM user WHERE id=? AND name=? AND age=?
==> Parameters: 0(Long), Jack(String), 20(Integer)
<==????? Total: 0

正在回答

2 回答

我懷疑是你實體類中的主鍵用的基本數據類型,基本數據類型的成員變量,例如long的默認值是0。所以會出現你那么現象,換成基本數據類型對應的包裝類即可,因為是引用類型,默認值為null。

0 回復 有任何疑惑可以回復我~

估計你User實體類的主鍵用的基本類型吧,默認會帶默認值0的,可以換為包裝類型試試

0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消

創建條件構造器傳入實體對象時,沒有設置主鍵值,查詢SQL日志顯示主鍵值為0

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號