Search in sources :

Example 41 with Value

use of jakarta.nosql.Value in project jnosql-diana-driver by eclipse.

the class DefaultHazelcastBucketManager method sql.

@Override
public Collection<Value> sql(String query, Map<String, Object> params) throws NullPointerException {
    requireNonNull(query, "sql is required");
    requireNonNull(params, "params is required");
    final StringBuilder finalQuery = new StringBuilder(query);
    final Consumer<Map.Entry<String, Object>> consumer = e -> {
        String key = ":" + e.getKey();
        int indexOf = query.indexOf(key);
        finalQuery.replace(indexOf, indexOf + key.length(), e.getValue().toString());
    };
    params.entrySet().forEach(consumer);
    return sql(new SqlPredicate(finalQuery.toString()));
}
Also used : KeyValueEntity(jakarta.nosql.keyvalue.KeyValueEntity) SqlPredicate(com.hazelcast.query.impl.predicates.SqlPredicate) Collection(java.util.Collection) Function(java.util.function.Function) Objects(java.util.Objects) TimeUnit(java.util.concurrent.TimeUnit) Consumer(java.util.function.Consumer) Value(jakarta.nosql.Value) Collectors.toList(java.util.stream.Collectors.toList) Duration(java.time.Duration) Map(java.util.Map) Objects.requireNonNull(java.util.Objects.requireNonNull) Optional(java.util.Optional) StreamSupport(java.util.stream.StreamSupport) Predicate(com.hazelcast.query.Predicate) IMap(com.hazelcast.map.IMap) SqlPredicate(com.hazelcast.query.impl.predicates.SqlPredicate)

Example 42 with Value

use of jakarta.nosql.Value in project jnosql-diana-driver by eclipse.

the class HazelcastBucketManagerQueryTest method shouldReturnActiveAndGreaterThan2000Predicate.

@Test
public void shouldReturnActiveAndGreaterThan2000Predicate() {
    Predicate predicate = and(equal("active", false), greaterEqual("year", 1990));
    Collection<Value> result = bucketManager.sql(predicate);
    assertEquals(2, result.size());
}
Also used : Value(jakarta.nosql.Value) Predicate(com.hazelcast.query.Predicate) Test(org.junit.jupiter.api.Test)

Example 43 with Value

use of jakarta.nosql.Value in project jnosql-diana by eclipse.

the class DelQueryParser method prepare.

public KeyValuePreparedStatement prepare(String query, BucketManager manager) {
    DelQuery delQuery = provider.apply(query);
    Params params = Params.newParams();
    List<Value> values = delQuery.getKeys().stream().map(k -> Values.getValue(k, params)).collect(toList());
    return DefaultKeyValuePreparedStatement.del(values, manager, params, query);
}
Also used : Value(jakarta.nosql.Value) List(java.util.List) Collectors.toList(java.util.stream.Collectors.toList) Stream(java.util.stream.Stream) DelQuery(jakarta.nosql.query.DelQuery) QueryException(jakarta.nosql.QueryException) BucketManager(jakarta.nosql.keyvalue.BucketManager) KeyValuePreparedStatement(jakarta.nosql.keyvalue.KeyValuePreparedStatement) ServiceLoaderProvider(jakarta.nosql.ServiceLoaderProvider) DelQueryProvider(jakarta.nosql.query.DelQuery.DelQueryProvider) Params(jakarta.nosql.Params) DelQuery(jakarta.nosql.query.DelQuery) Value(jakarta.nosql.Value) Params(jakarta.nosql.Params)

Example 44 with Value

use of jakarta.nosql.Value in project jnosql-diana by eclipse.

the class DelQueryParser method query.

Stream<Value> query(String query, BucketManager manager) {
    DelQuery delQuery = provider.apply(query);
    Params params = Params.newParams();
    List<Value> values = delQuery.getKeys().stream().map(k -> Values.getValue(k, params)).collect(toList());
    if (params.isNotEmpty()) {
        throw new QueryException("To run a query with a parameter use a PrepareStatement instead.");
    }
    List<Object> keys = values.stream().map(Value::get).collect(toList());
    manager.delete(keys);
    return Stream.empty();
}
Also used : Value(jakarta.nosql.Value) List(java.util.List) Collectors.toList(java.util.stream.Collectors.toList) Stream(java.util.stream.Stream) DelQuery(jakarta.nosql.query.DelQuery) QueryException(jakarta.nosql.QueryException) BucketManager(jakarta.nosql.keyvalue.BucketManager) KeyValuePreparedStatement(jakarta.nosql.keyvalue.KeyValuePreparedStatement) ServiceLoaderProvider(jakarta.nosql.ServiceLoaderProvider) DelQueryProvider(jakarta.nosql.query.DelQuery.DelQueryProvider) Params(jakarta.nosql.Params) DelQuery(jakarta.nosql.query.DelQuery) QueryException(jakarta.nosql.QueryException) Value(jakarta.nosql.Value) Params(jakarta.nosql.Params)

Example 45 with Value

use of jakarta.nosql.Value in project jnosql-diana by eclipse.

the class PutQueryParser method query.

Stream<Value> query(String query, BucketManager manager) {
    PutQuery putQuery = provider.apply(query);
    Params params = Params.newParams();
    Value key = Values.getValue(putQuery.getKey(), params);
    Value value = Values.getValue(putQuery.getValue(), params);
    Optional<Duration> ttl = putQuery.getTtl();
    if (params.isNotEmpty()) {
        throw new QueryException("To run a query with a parameter use a PrepareStatement instead.");
    }
    KeyValueEntity entity = KeyValueEntity.of(key.get(), value.get());
    if (ttl.isPresent()) {
        manager.put(entity, ttl.get());
    } else {
        manager.put(entity);
    }
    return Stream.empty();
}
Also used : QueryException(jakarta.nosql.QueryException) Value(jakarta.nosql.Value) Params(jakarta.nosql.Params) Duration(java.time.Duration) PutQuery(jakarta.nosql.query.PutQuery) KeyValueEntity(jakarta.nosql.keyvalue.KeyValueEntity)

Aggregations

Value (jakarta.nosql.Value)66 Test (org.junit.jupiter.api.Test)53 Params (jakarta.nosql.Params)23 List (java.util.List)16 TypeReference (jakarta.nosql.TypeReference)7 KeyValueEntity (jakarta.nosql.keyvalue.KeyValueEntity)7 KeyValuePreparedStatement (jakarta.nosql.keyvalue.KeyValuePreparedStatement)7 AtomicInteger (java.util.concurrent.atomic.AtomicInteger)7 QueryException (jakarta.nosql.QueryException)6 Column (jakarta.nosql.column.Column)6 BigInteger (java.math.BigInteger)6 Collectors.toList (java.util.stream.Collectors.toList)6 Stream (java.util.stream.Stream)6 ColumnQuery (jakarta.nosql.column.ColumnQuery)5 Map (java.util.Map)5 ServiceLoaderProvider (jakarta.nosql.ServiceLoaderProvider)4 BucketManager (jakarta.nosql.keyvalue.BucketManager)4 Person (jakarta.nosql.tck.entities.Person)4 Predicate (com.hazelcast.query.Predicate)3 ColumnCondition (jakarta.nosql.column.ColumnCondition)3