扩展

Kotlin 扩展 提供了用额外功能扩展现有类的能力。Spring Data Kotlin API 使用这些扩展为现有的 Spring API 添加新的 Kotlin 特定便利功能。

请记住,Kotlin 扩展需要导入才能使用。类似于静态导入,IDE 在大多数情况下应该会自动建议导入。

例如,Kotlin 具体化类型参数 为 JVM 泛型类型擦除 提供了解决方案,Spring Data 提供了一些扩展来利用此功能。这使得 Kotlin API 更好。

要检索 Java 中的 SWCharacter 对象列表,您通常会编写以下代码

Flux<SWCharacter> characters = template.query(SWCharacter.class).inTable("star-wars").all()

使用 Kotlin 和 Spring Data 扩展,您可以改为编写以下代码

val characters = template.query<SWCharacter>().inTable("star-wars").all()
// or (both are equivalent)
val characters : Flux<SWCharacter> = template.query().inTable("star-wars").all()

与 Java 一样,Kotlin 中的字符是强类型化的,但 Kotlin 的智能类型推断允许使用更短的语法。

Kotlin 的类型安全查询

Kotlin 通过其语言语法和扩展系统拥抱特定领域语言的创建。Spring Data MongoDB 附带一个 Kotlin 扩展,用于使用Kotlin 属性引用构建类型安全的查询。使用此扩展的查询通常可以提高可读性。Criteria 上的大多数关键字都有一个匹配的 Kotlin 扩展,例如 inValuesregex

以下示例解释了类型安全查询

import org.springframework.data.mongodb.core.query.*

mongoOperations.find<Book>(
  Query(Book::title isEqualTo "Moby-Dick")               (1)
)

mongoOperations.find<Book>(
  Query(titlePredicate = Book::title exists true)
)

mongoOperations.find<Book>(
  Query(
    Criteria().andOperator(
      Book::price gt 5,
      Book::price lt 10
    ))
)

// Binary operators
mongoOperations.find<BinaryMessage>(
  Query(BinaryMessage::payload bits { allClear(0b101) }) (2)
)

// Nested Properties (i.e. refer to "book.author")
mongoOperations.find<Book>(
  Query(Book::author / Author::name regex "^H")          (3)
)
1 isEqualTo() 是一个中缀扩展函数,接收类型为 KProperty<T>,返回 Criteria
2 对于位运算符,传递一个 lambda 参数,在其中调用 Criteria.BitwiseCriteriaOperators 的方法之一。
3 要构建嵌套属性,请使用 / 字符(重载运算符 div)。