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

com.abubusoft.kripton.android.annotation.BindSqlDelete Maven / Gradle / Ivy

There is a newer version: 8.2.0-rc.4
Show newest version
/*******************************************************************************
 * Copyright 2015, 2017 Francesco Benincasa ([email protected]).
 *
 * 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 com.abubusoft.kripton.android.annotation;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

/**
 * This annotation allows to delete a bean from a database. You can use bean as
 * input parameter or method parameters like bean property, but you can not use
 * mixed case.
 * 
 * 

* For example suppose we persist bean Person defined as follow: *

* *
 * @BindType
 * public class Person {
 * 	public long id;
 * 
 * 	public String name;
 * 
 * 	public String surname;
 * 
 * 	public String birthCity;
 * 
 * 	public Date birthDay;
 * }
 * 
* *

* The associated DAO interface is *

* *
 * @BindDao(Person.class)
 * public interface PersonDAO {
 * }
 * 
* *

Case 1 - Method use a bean type parameter

* *

* It's possible define a DELETE query with annotation {@link BindSqlDelete}. It * is possibile to define query parameter simply using method parameter with * same name of the bean property. *

* *
 * @BindDao(Person.class)
 * public interface PersonDAO {
 * 
 *  @BindDelete(where="name=${name} and surname=${surname}")
 *  void deleteOne(String name, @BindSqlParam("surname") temp);
 * 
 *  @BindDelete(where="name=${name} and surname=${surname}")
 *  long deleteTwo(String name, @BindSqlParam("surname") temp);
 * }
 * 
* *

* Each method parameter will be use like input parameter for query. The name of * parameters will be used to map field bean and then the column name of the * associated table. If you specify a return type for methods (like method * insertTwo), it has to be of type * int, long, Integer, Long. In this case, the return value will be * the id value of just inserted row. * *

Case 2 - method use its parameters like bean properties

* *

* The other way to define an DELETE SQL is using a bean as input parameter: * *

 * @BindDao(Person.class)
 * public interface PersonDAO {
 * 
 * 	@BindDelete(where = " id = ${bean.id} ")
 * 	void deleteThree(Person bean);
 * }
 * 
* *

* If you specify a return type for methods, it has to be of type * int, long, Integer, Long and it will contains the number of * deleted rows. *

* * * @author Francesco Benincasa ([email protected]) * */ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.METHOD) public @interface BindSqlDelete { /** * Where. * * @return the string */ String where() default ""; /** * *

* JQL value. With this attribute, it is possibile to specify directly the * JQL code. JQL means that you can write SQL using field's names and class * name indeed of column and table names. Moreover, it is possibile to * specify where to use the dynamic parts of query through dynamic * statements like DYNAMIC_WHERE, DYNAMIC_ORDER_BY, DYNAMIC_PAGE_SIZE, * DYNAMIC_PAGE_OFFSET, encapsulated in #{dynamic-part-name} *

* *

* For example, for a select statement, you can write: *

* *
	 * SELECT * FROM media WHERE mediaId IN (SELECT mediaId FROM fav WHERE #{DYNAMIC_WHERE}) ORDER BY indx DESC LIMIT 0, 100
	 * 
* * If you use this attribute, no other attributes can be defined for * the annotation. * * @return JQL code specified by user */ String jql() default ""; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy