Created
May 13, 2018 14:59
-
-
Save panlw/62f1dfda3965582a221d122295797edb to your computer and use it in GitHub Desktop.
MyBatis(Kotlin)
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
package com.example.repository | |
import com.example.domain.Customer | |
import org.apache.ibatis.annotations.Delete | |
import org.apache.ibatis.annotations.Insert | |
import org.apache.ibatis.annotations.Mapper | |
import org.apache.ibatis.annotations.Param | |
import org.apache.ibatis.annotations.Select | |
import org.apache.ibatis.annotations.SelectKey | |
import org.apache.ibatis.annotations.Update | |
@Mapper | |
interface CustomerRepository { | |
@Select("SELECT * FROM customers ORDER BY id") | |
fun findAll(): List<Customer> | |
@Select("SELECT * FROM customers WHERE id = #{id}") | |
fun findOne(@Param("id") id: Int): Customer | |
@Insert("INSERT INTO customers(first_name, last_name, address) VALUES(#{firstName}, #{lastName}, #{address})") | |
@SelectKey(statement = arrayOf("call identity()"), keyProperty = "id", before = false, resultType = Int::class) | |
fun insert(customer: Customer) | |
@Update("UPDATE customers SET first_name = #{firstName}, last_name = #{lastName}, address = #{address} WHERE id = #{id}") | |
fun update(customer: Customer) | |
@Delete("DELETE FROM customers WHERE id = #{id}") | |
fun delete(@Param("id") id: Int); | |
@Select(""" | |
SELECT | |
* | |
FROM | |
customers | |
WHERE | |
first_name LIKE '%' || #{firstName} || '%' | |
ORDER BY id | |
""") | |
fun findByFirstName(@Param("firstName") firstName: String): List<Customer> | |
@Delete("DELETE FROM customers") | |
fun deleteAll() | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment