All Downloads are FREE. Search and download functionalities are using the official Maven repository.

protobuf4j.orm.sql.clause.OrderByClause Maven / Gradle / Ivy

The newest version!
package protobuf4j.orm.sql.clause;

import com.google.common.collect.Lists;
import lombok.Data;
import protobuf4j.orm.sql.AbstractSqlObject;
import protobuf4j.orm.sql.Direction;
import protobuf4j.orm.sql.IExpression;
import protobuf4j.orm.sql.ISqlValue;
import protobuf4j.orm.sql.expr.Column;

import javax.annotation.Nonnull;
import java.util.List;

/**
 * author: yuanwq
 * date: 2018/7/12
 */
@Data
public class OrderByClause extends AbstractSqlObject {
  private final List orderByItems = Lists.newArrayList();

  public OrderByClause clear() {
    orderByItems.clear();
    return this;
  }

  private OrderByClause addOrderByItem(OrderByItem orderByItem) {
    this.orderByItems.add(orderByItem);
    return this;
  }

  public OrderByClause by(IExpression expr) {
    return addOrderByItem(new OrderByItem(expr));
  }

  public OrderByClause by(String column) {
    return by(Column.of(column));
  }

  public OrderByClause asc(IExpression expr) {
    return addOrderByItem(new OrderByItem(expr, Direction.ASC));
  }

  public OrderByClause asc(String column) {
    return asc(Column.of(column));
  }

  public OrderByClause desc(IExpression expr) {
    return addOrderByItem(new OrderByItem(expr, Direction.DESC));
  }

  public OrderByClause desc(String column) {
    return desc(Column.of(column));
  }

  public boolean isEmpty() {
    return orderByItems.isEmpty();
  }

  @Override
  public StringBuilder toSqlTemplate(@Nonnull StringBuilder sb) {
    if (orderByItems.isEmpty()) {
      return sb;
    }
    sb.append("ORDER BY ");
    boolean first = true;
    for (OrderByItem expr : orderByItems) {
      if (first) {
        first = false;
      } else {
        sb.append(",");
      }
      expr.toSqlTemplate(sb);
    }
    return sb;
  }

  @Override
  public StringBuilder toSolidSql(@Nonnull StringBuilder sb) {
    if (orderByItems.isEmpty()) {
      return sb;
    }
    sb.append("ORDER BY ");
    boolean first = true;
    for (OrderByItem expr : orderByItems) {
      if (first) {
        first = false;
      } else {
        sb.append(",");
      }
      expr.toSolidSql(sb);
    }
    return sb;
  }

  @Override
  public List collectSqlValue(@Nonnull List sqlValues) {
    for (OrderByItem expr : orderByItems) {
      expr.collectSqlValue(sqlValues);
    }
    return sqlValues;
  }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy