/* * Copyright 2015, The Querydsl Team (http://www.querydsl.com/team) * * 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.querydsl.core.types.dsl; import java.sql.Time; import javax.annotation.Nullable; import com.querydsl.core.types.Expression; import com.querydsl.core.types.ExpressionUtils; import com.querydsl.core.types.Ops; import com.querydsl.core.types.Path; /** * {@code TimeExpression} represents Time expressions * * @author tiwe * * @param <T> expression type */ public abstract class TimeExpression<T extends Comparable> extends TemporalExpression<T> { private static final long serialVersionUID = 7360552308332457990L; private static class Constants { private static final TimeExpression<Time> CURRENT_TIME = currentTime(Time.class); } @Nullable private transient volatile NumberExpression<Integer> hours, minutes, seconds, milliseconds; public TimeExpression(Expression<T> mixin) { super(mixin); } @Override public TimeExpression<T> as(Path<T> alias) { return Expressions.timeOperation(getType(),Ops.ALIAS, mixin, alias); } @Override public TimeExpression<T> as(String alias) { return as(ExpressionUtils.path(getType(), alias)); } /** * Create a hours expression (range 0-23) * * @return hour */ public NumberExpression<Integer> hour() { if (hours == null) { hours = Expressions.numberOperation(Integer.class, Ops.DateTimeOps.HOUR, mixin); } return hours; } /** * Create a minutes expression (range 0-59) * * @return minute */ public NumberExpression<Integer> minute() { if (minutes == null) { minutes = Expressions.numberOperation(Integer.class, Ops.DateTimeOps.MINUTE, mixin); } return minutes; } /** * Create a seconds expression (range 0-59) * * @return second */ public NumberExpression<Integer> second() { if (seconds == null) { seconds = Expressions.numberOperation(Integer.class, Ops.DateTimeOps.SECOND, mixin); } return seconds; } /** * Create a milliseconds expression (range 0-999) * <p>Is always 0 in JPA and JDO modules</p> * * @return milli second */ public NumberExpression<Integer> milliSecond() { if (milliseconds == null) { milliseconds = Expressions.numberOperation(Integer.class, Ops.DateTimeOps.MILLISECOND, mixin); } return milliseconds; } /** * Create an expression representing the current time as a TimeExpression instance * * @return current time */ public static TimeExpression<Time> currentTime() { return Constants.CURRENT_TIME; } /** * Create an expression representing the current time as a TimeExpression instance * * @return current time */ public static <T extends Comparable> TimeExpression<T> currentTime(Class<T> cl) { return Expressions.timeOperation(cl, Ops.DateTimeOps.CURRENT_TIME); } }