創建條件構造器傳入實體對象時,沒有設置主鍵值,查詢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
2020-07-05
我懷疑是你實體類中的主鍵用的基本數據類型,基本數據類型的成員變量,例如long的默認值是0。所以會出現你那么現象,換成基本數據類型對應的包裝類即可,因為是引用類型,默認值為null。
2020-06-12
估計你User實體類的主鍵用的基本類型吧,默認會帶默認值0的,可以換為包裝類型試試