/* * This program is free software; you can redistribute it and/or modify it under the terms of * the GNU General Public License as published by the Free Software Foundation; either version 3 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 Public License for more details. * You should have received a copy of the GNU General Public License along with this program; * if not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ package com.meidusa.amoeba.parser.expression; import com.meidusa.amoeba.parser.dbobject.Column; /** * * @author <a href=mailto:piratebase@sina.com>Struct chen</a> * */ public class ColumnExpression extends Expression { private Column column; private ComparisonExpression expression; //�õ��У��� public Column getColumn() { return column; } /** * ����column��ֵ * @param column */ public void setColumn(Column column) { this.column = column; } /** * ������expression��ֵ * @param expression */ public void setExpression(ComparisonExpression expression){ this.expression = expression; } /*** * ���ʽȡ�� */ public Expression reverse(){ expression.reverse(); return this; } /** * �õ����ʽ(expression) * @return */ public Expression getExpression(){ return expression; } /** * �Ƿ���Ҫʵʱ���� */ public boolean isRealtime(){ return expression.isRealtime(); } /* ���ʽ���� * (non-Javadoc) * @see com.meidusa.amoeba.parser.expression.Expression#evaluate(java.lang.Object[]) */ @SuppressWarnings("unchecked") @Override public Comparable evaluate(Object[] parameters) { return expression.evaluate(parameters); } /** * ת�����ַ��� */ public String toString(){ StringBuilder builder = new StringBuilder(); toString(builder); return builder.toString(); } @Override protected void toString(StringBuilder builder) { if(column == null){ return; }else{ builder.append(" "); builder.append(column.getSql()); if(expression != null){ expression.toString(builder); } } } }