/* * Copyright (C) 2016 The Android Open Source Project * * Licensed 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 androidx.room; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; /** * Marks a method in a {@link Dao} annotated class as an insert method. *

* The implementation of the method will insert its parameters into the database. *

* All of the parameters of the Insert method must either be classes annotated with {@link Entity} * or collections/array of it. *

* Example: *

 * {@literal @}Dao
 * public interface MyDao {
 *     {@literal @}Insert(onConflict = OnConflictStrategy.REPLACE)
 *     public void insertUsers(User... users);
 *     {@literal @}Insert
 *     public void insertBoth(User user1, User user2);
 *     {@literal @}Insert
 *     public void insertWithFriends(User user, List<User> friends);
 * }
 * 
* * @see Update * @see Delete */ @Target({ElementType.METHOD}) @Retention(RetentionPolicy.CLASS) public @interface Insert { /** * What to do if a conflict happens. * @see SQLite conflict documentation * * @return How to handle conflicts. Defaults to {@link OnConflictStrategy#ABORT}. */ @OnConflictStrategy int onConflict() default OnConflictStrategy.ABORT; }