1. 程式人生 > >mybatis example處理and、or關係的方法(轉載wang_song_yan)作者不是我,我拿來備忘,謝謝原作者

mybatis example處理and、or關係的方法(轉載wang_song_yan)作者不是我,我拿來備忘,謝謝原作者

mybatis example處理and、or關係的方法

2015年10月12日 23:02:43 wang_song_yan 閱讀數:28693 標籤: javaweb mybatis criteria sql andor 更多

個人分類: JavaWeb

1.( xx and xx) or ( xx and xx) 

例項程式碼:

 

 
  1. BaUserExample baUserExample = new BaUserExample();

  2.  
  3. Criteria criteria1 = baUserExample.createCriteria();

  4. criteria1.andOrgIdEqualTo("1");

  5. criteria1.andDeptIdEqualTo("1");

  6.  
  7. Criteria criteria2 = baUserExample.createCriteria();

  8. criteria2.andUserNameEqualTo("name");

  9. criteria2.andEmailLike("%[email protected]%");

  10.  
  11. baUserExample.or(criteria2);

  12.  
  13. userMapper.countByExample(baUserExample);

 

 

執行的sql語句:

 

==>  Preparing: select count(*) from ba_user WHERE ( org_id = ? and dept_id = ? ) or( user_name = ? and email like ? )

 

2.xx and ( xx or xx)

暫時沒找到直接的sql語句構造方法,但是經過轉換還是可以實現的

根據邏輯表示式可以知道 a and ( b or c ) = ( a and b) or ( a and c )

所以就轉變成第一種方法

舉個例子,假如想要實現 select count(*) from ba_user WHERE userName like ? and ( dept_id is null or dept_id <>? )

可以轉化為select count(*) from ba_user WHERE (userName like ? and  dept_id is null ) or ( userName like ? and  dept_id <>? )

例項程式碼:

 

 
  1. BaUserExample baUserExample = new BaUserExample();

  2.  
  3. Criteria criteria1 = baUserExample.createCriteria();

  4. criteria1.andUserNameLike("%name%");

  5. criteria1.andDeptIdIsNull();

  6.  
  7. Criteria criteria2 = baUserExample.createCriteria();

  8. criteria2.andUserNameLike("%name%");

  9. criteria2.andDeptIdNotEqualTo("1");

  10.  
  11. baUserExample.or(criteria2);

  12.  
  13. userMapper.countByExample(baUserExample);

 

 

執行的sql語句:

 

==>  Preparing: select count(*) from ba_user WHERE ( user_name like ? and dept_id is null ) or( user_name like ? and dept_id <> ? ) 


這算是一種取巧的方法吧,對於這樣的問題可以自己編寫mapper.xml檔案,或者在程式碼裡面過濾,還有一種思路就是修改Criteria的程式碼實現and和or功能調換(還沒嘗試過)。