import static org.mybatis.dynamic.sql.SqlBuilder.isEqualToWhenPresent;
import static org.mybatis.dynamic.sql.SqlBuilder.isIn;
import static org.mybatis.dynamic.sql.SqlBuilder.isNull;
import org.mybatis.dynamic.sql.select.MyBatis3SelectModelAdapter;
import org.mybatis.dynamic.sql.select.QueryExpressionDSL;
...
@Override
public Optional> searchEmployees(EmployeeCondition byCondition) {
QueryExpressionDSL>>.QueryExpressionWhereBuilder dsl =mapper.selectByExample()
.where(BpsnDynamicSqlSupport.bpeno, isEqualToWhenPresent(byCondition.getBpeno()))
.and(BpsnDynamicSqlSupport.alias, isEqualToWhenPresent(byCondition.getAlias()))
.and(BpsnDynamicSqlSupport.bpnme, isEqualToWhenPresent(byCondition.getBpnme()))
.and(BpsnDynamicSqlSupport.mobile1, isEqualToWhenPresent(byCondition.getMobile1()))
.and(BpsnDynamicSqlSupport.address, isEqualToWhenPresent(byCondition.getAddress()))
.and(BpsnDynamicSqlSupport.passportno, isEqualToWhenPresent(byCondition.getPassportno()));
if(EmployeeQuery.ACTIVE.equals(EmployeeQuery.valueOf(byCondition.getWorkType()))) {
dsl.and(BpsnDynamicSqlSupport.bpedy, isNull());
}else if(EmployeeQuery.TRANSFER.equals(EmployeeQuery.valueOf(byCondition.getWorkType()))) {
dsl.and(BpsnDynamicSqlSupport.deptNo, isIn("L","M"));
}
List list = dsl.build().execute();
return list==null ? Optional.empty() : Optional.of(list);
}
2019年5月6日 星期一
Mybatis dynamic sql
這次專案是對既有的DB資料來開發系統,用到 Mybatis的generator 和dynamic sql 產生mapper及sql語法(不用寫任何的xml及欄位對應) 其中selectByExample 是對所有欄位都取出,但條件是依照web UI所輸入的欄位動態產生where condition,isEqualToWhenPresent就是當參數非null才會產生該條件,另外一個需求是需透過程式的if condition來動態加上條件。這些寫法也是透過官網的範例逐一摸索出來的,給有需要的人參考看看。
訂閱:
張貼留言 (Atom)
COVID-19 確診經歷紀實
原本以為真的是天選之人,就算先前家裡兩個小孩都確診都逃過了(可能有中獎但無症狀吧),不過就在2023年六月18日破解自認為天選之人的"心態",為什麼可以確認就是這天中獎的呢?因為在前都是居家上班,到人多的室內場所都會戴口罩,就剛好這天傍晚原本只想說要去附近的國...
-
20090514中午後突然落枕,隔天中午後就請假回家,到中和南勢角捷運一號出口的漢唐中醫去看醫生了,三點左右居然還爆多人 = = ,一開始看完醫生後就針灸,約十五分後推拿最後拔灌,脖子就有好一點了,隔天恢復更多,差不多有七八成了,再隔天就痊癒了。其實為啥會在非睡覺姿勢落枕勒,醫生...
-
Java Architecture for XML Binding (JAXB) 這個 lib 已經在jdk 1.6內 , 所以不用額外下載了。 用法很簡單,看 官方的文件 就很清楚了,由XML轉成(parse、unmarshal)物件,或由物件產生(marsha...
-
這次的總冠軍很有話題性,適逢恰恰的球員生涯結束和Lamigo的三年霸夢想與轉賣,當然這是眾所皆知的話題,比賽結果雖然失望但對我這種看過大風大浪的棒球迷來說沒什麼好感傷反而是因為兩位寶貝女兒(九歲及六歲)第一次看總冠軍賽,樂趣在於和家人一起熱忠於看棒球的過程。 來說說這次總冠軍...
沒有留言:
張貼留言