/* * #%L * JSQLParser library * %% * Copyright (C) 2004 - 2013 JSQLParser * %% * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation, either version 2.1 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Lesser Public License for more details. * * You should have received a copy of the GNU General Lesser Public * License along with this program. If not, see * <http://www.gnu.org/licenses/lgpl-2.1.html>. * #L% */ package net.sf.jsqlparser.statement.select; import net.sf.jsqlparser.expression.Expression; /** * An element (column reference) in an "ORDER BY" clause. */ public class OrderByElement { public enum NullOrdering { NULLS_FIRST, NULLS_LAST } private Expression expression; private boolean asc = true; private NullOrdering nullOrdering; private boolean ascDesc = false; public boolean isAsc() { return asc; } public NullOrdering getNullOrdering() { return nullOrdering; } public void setNullOrdering(NullOrdering nullOrdering) { this.nullOrdering = nullOrdering; } public void setAsc(boolean b) { asc = b; } public void setAscDescPresent(boolean b) { ascDesc = b; } public boolean isAscDescPresent() { return ascDesc; } public void accept(OrderByVisitor orderByVisitor) { orderByVisitor.visit(this); } public Expression getExpression() { return expression; } public void setExpression(Expression expression) { this.expression = expression; } @Override public String toString() { StringBuilder b = new StringBuilder(); b.append(expression.toString()); if (!asc) { b.append(" DESC"); } else if (ascDesc) { b.append(" ASC"); } if (nullOrdering != null) { b.append(' '); b.append(nullOrdering == NullOrdering.NULLS_FIRST ? "NULLS FIRST" : "NULLS LAST"); } return b.toString(); } }