com.datastax.oss.driver.api.mapper.annotations.Insert Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.datastax.oss.driver.api.mapper.annotations;
import com.datastax.dse.driver.api.core.cql.reactive.ReactiveResultSet;
import com.datastax.oss.driver.api.core.CqlIdentifier;
import com.datastax.oss.driver.api.core.cql.BoundStatement;
import com.datastax.oss.driver.api.core.cql.ResultSet;
import com.datastax.oss.driver.api.core.session.Session;
import com.datastax.oss.driver.api.core.session.SessionBuilder;
import com.datastax.oss.driver.api.mapper.entity.saving.NullSavingStrategy;
import com.datastax.oss.driver.api.mapper.result.MapperResultProducer;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import java.util.Optional;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.CompletionStage;
import java.util.function.Function;
import java.util.function.UnaryOperator;
/**
* Annotates a {@link Dao} method that inserts an instance of an {@link Entity}-annotated class.
*
* Example:
*
*
* @Dao
* public interface ProductDao {
* @Insert
* void insert(Product product);
* }
*
*
* Parameters
*
* The first parameter must be the entity to insert.
*
* If the query has a {@linkplain #ttl() TTL} and/or {@linkplain #timestamp() timestamp} with
* placeholders, the method must have corresponding additional parameters (same name, and a
* compatible Java type):
*
*
* @Insert(ttl = ":ttl")
* void insertWithTtl(Product product, int ttl);
*
*
* A {@link Function Function<BoundStatementBuilder, BoundStatementBuilder>} or {@link
* UnaryOperator UnaryOperator<BoundStatementBuilder>} can be added as the last
* parameter. It will be applied to the statement before execution. This allows you to customize
* certain aspects of the request (page size, timeout, etc) at runtime.
*
*
Return type
*
* The method can return:
*
*
* - {@code void}.
*
- the entity class. This is intended for {@code INSERT ... IF NOT EXISTS} queries. The method
* will return {@code null} if the insertion succeeded, or the existing entity if it failed.
*
* @Insert(ifNotExists = true)
* Product insertIfNotExists(Product product);
*
* - an {@link Optional} of the entity class, as a null-safe alternative for {@code INSERT ...
* IF NOT EXISTS} queries.
*
* @Insert(ifNotExists = true)
* Optional<Product> insertIfNotExists(Product product);
*
* - a {@code boolean} or {@link Boolean}, which will be mapped to {@link
* ResultSet#wasApplied()}. This is intended for IF NOT EXISTS queries:
*
* @Insert(ifNotExists = true)
* boolean saveIfNotExists(Product product);
*
* - a {@link ResultSet}. This is intended for cases where you intend to inspect data associated
* with the result, such as {@link ResultSet#getExecutionInfo()}.
*
* @Insert
* ResultSet save(Product product);
*
* - a {@link BoundStatement} This is intended for cases where you intend to execute this
* statement later or in a batch:
*
* @Insert
* BoundStatement save(Product product);
*
* - a {@link CompletionStage} or {@link CompletableFuture} of any of the above. The mapper will
* execute the query asynchronously.
*
* @Insert
* CompletionStage<Void> insert(Product product);
*
* @Insert(ifNotExists = true)
* CompletableFuture<Product> insertIfNotExists(Product product);
*
* @Insert(ifNotExists = true)
* CompletableFuture<Optional<Product>> insertIfNotExists(Product product);
*
* - a {@link ReactiveResultSet}.
*
* @Insert
* ReactiveResultSet insertReactive(Product product);
*
* - a {@linkplain MapperResultProducer custom type}.
*
*
* Target keyspace and table
*
* If a keyspace was specified when creating the DAO (see {@link DaoFactory}), then the generated
* query targets that keyspace. Otherwise, it doesn't specify a keyspace, and will only work if the
* mapper was built from a {@link Session} that has a {@linkplain
* SessionBuilder#withKeyspace(CqlIdentifier) default keyspace} set.
*
* If a table was specified when creating the DAO, then the generated query targets that table.
* Otherwise, it uses the default table name for the entity (which is determined by the name of the
* entity class and the naming convention).
*/
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface Insert {
/** Whether to append an IF NOT EXISTS clause at the end of the generated INSERT query. */
boolean ifNotExists() default false;
/**
* The TTL (time to live) to use in the generated INSERT query.
*
*
If this starts with ":", it is interpreted as a named placeholder (that must have a
* corresponding parameter in the method signature). Otherwise, it must be a literal integer value
* (representing a number of seconds).
*
*
If the placeholder name is invalid or the literal can't be parsed as an integer (according
* to the rules of {@link Integer#parseInt(String)}), the mapper will issue a compile-time
* warning.
*/
String ttl() default "";
/**
* The timeout to use in the generated INSERT query. Equivalent to {@code USING TIMEOUT
* } clause.
*
* If this starts with ":", it is interpreted as a named placeholder (that must have a
* corresponding parameter in the method signature). Otherwise, it must be a String representing a
* valid CqlDuration.
*
*
If the placeholder name is invalid or the literal can't be parsed as a CqlDuration
* (according to the rules of {@link
* com.datastax.oss.driver.api.core.data.CqlDuration#from(String)}), the mapper will issue a
* compile-time error.
*/
String usingTimeout() default "";
/**
* The timestamp to use in the generated INSERT query.
*
*
If this starts with ":", it is interpreted as a named placeholder (that must have a
* corresponding parameter in the method signature). Otherwise, it must be literal long value
* (representing a number of microseconds since epoch).
*
*
If the placeholder name is invalid or the literal can't be parsed as a long (according to
* the rules of {@link Long#parseLong(String)}), the mapper will issue a compile-time warning.
*/
String timestamp() default "";
/**
* How to handle null entity properties during the insertion.
*
*
This defaults either to the {@link DefaultNullSavingStrategy DAO-level strategy} (if set),
* or {@link NullSavingStrategy#DO_NOT_SET}.
*/
NullSavingStrategy nullSavingStrategy() default NullSavingStrategy.DO_NOT_SET;
}