Open Source Repository

Home /hibernate/hibernate-3.2.6.ga | Repository Home


org/hibernate/sql/HSQLCaseFragment.java
//$Id: HSQLCaseFragment.java 3890 2004-06-03 16:31:32Z steveebersole $
package org.hibernate.sql;

import java.util.Iterator;
import java.util.Map;

/**
 * The HSQL CASEWHEN function.
 <br>
 <code>casewhen(..., ..., ...) as ...</code>
 <br>
 @author Wolfgang Jung
 */
public class HSQLCaseFragment extends CaseFragment {

  public String toFragmentString() {
    StringBuffer buf = new StringBuffercases.size() 15 10 );
    StringBuffer buf2 = new StringBuffercases.size() );

    Iterator iter = cases.entrySet().iterator();
    while iter.hasNext() ) {
      Map.Entry me = (Map.Entryiter.next();
      buf.append(" casewhen(")
        .appendme.getKey() )
        .append(" is not null")
        .append(", ")
        .appendme.getValue() )
        .append(", ");
      buf2.append(")");
    }

    buf.append("-1")//null caused some problems
    buf.appendbuf2.toString() );
    if returnColumnName!=null ) {
      buf.append(" as ")
        .append(returnColumnName);
    }
    return buf.toString();
  }
}