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

com.avaje.ebeaninternal.server.query.RawSqlQueryPlanKey Maven / Gradle / Ivy

package com.avaje.ebeaninternal.server.query;

import com.avaje.ebeaninternal.api.CQueryPlanKey;

/**
 * QueryPlanKey for RawSql queries.
 */
public class RawSqlQueryPlanKey implements CQueryPlanKey {

  private final String sql;
  private final boolean rawSql;
  private final boolean rowNumberIncluded;
  private final String logWhereSql;

  public RawSqlQueryPlanKey(String sql, boolean rawSql, boolean rowNumberIncluded, String logWhereSql) {
    this.sql = sql;
    this.rawSql = rawSql;
    this.rowNumberIncluded = rowNumberIncluded;
    this.logWhereSql = logWhereSql;
  }

  public String toString() {
    return getPartialKey() + ":r";
  }

  /**
   * Return as a partial key. For rawSql hash the sql is part of the key and as such
   * needs to be included in order to have a complete key. Typically the MD5 of the sql
   * can be used as a short form proxy for the actual sql.
   */
  public String getPartialKey() {
    return hashCode() + "_0";
  }

  @Override
  public boolean equals(Object o) {
    if (this == o) return true;
    if (o == null || getClass() != o.getClass()) return false;

    RawSqlQueryPlanKey that = (RawSqlQueryPlanKey) o;

    if (rawSql != that.rawSql) return false;
    if (rowNumberIncluded != that.rowNumberIncluded) return false;
    if (!sql.equals(that.sql)) return false;
    return logWhereSql != null ? logWhereSql.equals(that.logWhereSql) : that.logWhereSql == null;
  }

  @Override
  public int hashCode() {
    int result = sql.hashCode();
    result = 31 * result + (rawSql ? 1 : 0);
    result = 31 * result + (rowNumberIncluded ? 1 : 0);
    result = 31 * result + logWhereSql.hashCode();
    return result;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy