
org.jnosql.artemis.column.query.ArtemisColumnQuery Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of artemis-column Show documentation
Show all versions of artemis-column Show documentation
Eclipse JNoSQL Mapping, Artemis API, to column NoSQL databases
/*
* Copyright (c) 2017 Otávio Santana and others
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* and Apache License v2.0 which accompanies this distribution.
* The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
* and the Apache License v2.0 is available at http://www.opensource.org/licenses/apache2.0.php.
*
* You may elect to redistribute this code under either of these licenses.
*
* Contributors:
*
* Otavio Santana
*/
package org.jnosql.artemis.column.query;
import org.jnosql.diana.api.Sort;
import org.jnosql.diana.api.column.ColumnCondition;
import org.jnosql.diana.api.column.ColumnQuery;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import static java.util.Collections.emptyList;
class ArtemisColumnQuery implements ColumnQuery {
private final List sorts;
private final long limit;
private final long start;
private final ColumnCondition condition;
private final String columnFamily;
public ArtemisColumnQuery(List sorts, long limit, long start, ColumnCondition condition, String columnFamily) {
this.sorts = sorts;
this.limit = limit;
this.start = start;
this.condition = condition;
this.columnFamily = columnFamily;
}
@Override
public long getMaxResults() {
return limit;
}
@Override
public long getFirstResult() {
return start;
}
@Override
public String getColumnFamily() {
return columnFamily;
}
@Override
public Optional getCondition() {
return Optional.ofNullable(condition);
}
@Override
public List getColumns() {
return emptyList();
}
@Override
public List getSorts() {
return sorts;
}
@Override
public boolean equals(Object o) {
if (this == o) {
return true;
}
if (!(o instanceof ColumnQuery)) {
return false;
}
ColumnQuery that = (ColumnQuery) o;
return limit == that.getMaxResults()
&& start == that.getFirstResult()
&& Objects.equals(sorts, that.getSorts())
&& Objects.equals(condition, that.getCondition().orElse(null))
&& Objects.equals(columnFamily, that.getColumnFamily());
}
@Override
public int hashCode() {
return Objects.hash(limit, start, columnFamily, emptyList(), sorts, condition);
}
@Override
public String toString() {
final StringBuilder sb = new StringBuilder("ArtemisColumnQuery{");
sb.append("maxResults=").append(limit);
sb.append(", firstResult=").append(start);
sb.append(", columnFamily='").append(columnFamily).append('\'');
sb.append(", columns=").append(emptyList());
sb.append(", sorts=").append(sorts);
sb.append(", condition=").append(condition);
sb.append('}');
return sb.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy