com.wavemaker.runtime.data.periods.BetweenClause Maven / Gradle / Ivy
/*******************************************************************************
* Copyright (C) 2022-2023 WaveMaker, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
******************************************************************************/
package com.wavemaker.runtime.data.periods;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import com.wavemaker.runtime.data.annotations.TableTemporal;
import com.wavemaker.runtime.data.filter.WMQueryInfo;
import com.wavemaker.runtime.data.filter.WMQueryParamInfo;
/**
* @author Dilip Kumar
* @since 29/11/17
*/
public class BetweenClause implements PeriodClause {
private final TableTemporal.TemporalType type;
private final Date from;
private final Date to;
public BetweenClause(final TableTemporal.TemporalType type, final Date from, final Date to) {
this.type = type;
this.from = from;
this.to = to;
}
@Override
public WMQueryInfo asWMQueryClause() {
String var1Name = "wm_" + type.asHqlKeyword() + "_from_timestamp";
String var2Name = "wm_" + type.asHqlKeyword() + "_and_timestamp";
String hql = type.asHqlKeyword() + " between :" + var1Name + " and :" + var2Name;
Map parameters = new HashMap<>(2);
parameters.put(var1Name, new WMQueryParamInfo(from));
parameters.put(var2Name, new WMQueryParamInfo(to));
return new WMQueryInfo(hql, parameters);
}
}