/*
  Copyright (C) 2006 Helge Hess

  This file is part of JOPE.

  JOPE 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, or (at your option) any
  later version.

  JOPE 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 Lesser General Public
  License for more details.

  You should have received a copy of the GNU Lesser General Public
  License along with JOPE; see the file COPYING.  If not, write to the
  Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA
  02111-1307, USA.
*/

package org.opengroupware.jope.eoaccess.mysql;

import org.opengroupware.jope.eoaccess.EOEntity;
import org.opengroupware.jope.eoaccess.EOSQLExpression;
import org.opengroupware.jope.eocontrol.EOQualifier;

public class EOMySQLExpression extends EOSQLExpression {

  public EOMySQLExpression(EOEntity _entity) {
    super(_entity);
  }

  /* database SQL */
  
  public String externalNameQuoteCharacter() {
    /* backtick for MySQL */
    return "`";
  }
  
  public String sqlStringForSelector
    (EOQualifier.ComparisonOperation _op, Object _value, boolean _allowNull)
  {
    /*
     * This is for MySQL 4.1, possibly it has been fixed in later versions.
     * 
     * Check the MySQL manual:
     *   12.3.1. String Comparison Functions
     *   
     *   Normally, if any expression in a string comparison is case sensitive,
     *   the comparison is performed in case-sensitive fashion.
     * 
     * A regular
     *   name LIKE 'abc%'
     * is _case insensitive_! To achieve case sensitivity you need to use
     * LIKE BINARY:
     *   name LIKE BINARY 'abc%'
     */
    
    if (_op == EOQualifier.ComparisonOperation.CASE_INSENSITIVE_LIKE)
      return "LIKE";
    if (_op == EOQualifier.ComparisonOperation.LIKE)
      return "LIKE BINARY";
    
    return super.sqlStringForSelector(_op, _value, _allowNull);
  }
}
