Packages

abstract class Molecule09[A, B, C, D, E, F, G, H, I] extends Molecule[(A, B, C, D, E, F, G, H, I)]

Source
Molecule.scala
Linear Supertypes
Molecule[(A, B, C, D, E, F, G, H, I)], ShowDebug[(A, B, C, D, E, F, G, H, I)], GetJson, GetRaw, GetList[(A, B, C, D, E, F, G, H, I)], GetIterable[(A, B, C, D, E, F, G, H, I)], GetArray[(A, B, C, D, E, F, G, H, I)], JsonBuilder, CastHelpers[(A, B, C, D, E, F, G, H, I)], Helpers, MoleculeBase, AnyRef, Any
Ordering
  1. Grouped
  2. Alphabetic
  3. By Inheritance
Inherited
  1. Molecule09
  2. Molecule
  3. ShowDebug
  4. GetJson
  5. GetRaw
  6. GetList
  7. GetIterable
  8. GetArray
  9. JsonBuilder
  10. CastHelpers
  11. Helpers
  12. MoleculeBase
  13. AnyRef
  14. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new Molecule09(_model: Model, queryData: (Query, Option[Query]))

Type Members

  1. trait checkInsertModel extends AnyRef

    Insert data is verified on instantiation of insert object in each arity molecule

    Insert data is verified on instantiation of insert object in each arity molecule

    Attributes
    protected
    Definition Classes
    Molecule
  2. trait debugInsert extends AnyRef

    Debug call to insert on a molecule (without affecting the db).

    Debug call to insert on a molecule (without affecting the db).

    Prints internal molecule transformation representations to output:

    Model --> Generic statements --> Datomic statements

    Definition Classes
    Molecule
  3. trait getInsertTx extends AnyRef

    Get transaction statements of a call to insert on a molecule (without affecting the db).

    Get transaction statements of a call to insert on a molecule (without affecting the db).

    returns

    Transaction statements

    Definition Classes
    Molecule
  4. trait insert extends AnyRef

    Insert one or more rows of data matching molecule.

    Insert one or more rows of data matching molecule.

    Data matching the types of the molecule can be inserted either as individual args or an Iterable (List, Set etc) of tuples:

    // Insert single row of data with individual args
    Person.name.age.insert("Ann", 28)
    
    // Insert multiple rows of data. Accepts Iterable[Tpl]
    Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37),
    )
    
    // Data was inserted
    Person.name.age.get.sorted === List(
      ("Ann", 28),
      ("Ben", 42),
      ("Liz", 37),
    )

    Each insert apply method returns a TxReport with info about the result of the transaction.

    Since insert is an object of each arity 1-22 Molecule implementation, we can make an "insert-molecule" at compile time that we can re-use for inserting data at runtime matching the molecule type:

    // At compiletime:
    
    // Make insert-molecule
    val insertPersonsWithAge = Person.name.age.insert
    
    // At runtime:
    
    // Apply individual args matching insert-molecule to insert single row
    insertPersonsWithAge("Ann", 28)
    
    // .. or apply Iterable of tuples matching insert-molecule to insert multiple rows
    insertPersonsWithAge(
      List(
        ("Ben", 42),
        ("Liz", 37),
      )
    )
    
    // Data was inserted
    Person.name.age.get.sorted === List(
      ("Ann", 28),
      ("Ben", 42),
      ("Liz", 37),
    )

    The insert operation is synchronous and can be wrapped in a Future if asynchronicity is required.

    (This trait is simply a marker being extend to by insert objects in each arity 1-22 Molecule implementation to make this documentation available).

    Definition Classes
    Molecule

Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. def _debugInsert(conn: Conn, data: Iterable[Seq[Any]]): Unit
    Attributes
    protected
    Definition Classes
    ShowDebug
  5. def _getInsertTx(conn: Conn, data: Iterable[Seq[Any]]): Seq[Seq[Statement]]
    Attributes
    protected
    Definition Classes
    Molecule
  6. def _insert(conn: Conn, model: Model, dataRows: Iterable[Seq[Any]] = Seq()): TxReport
    Attributes
    protected
    Definition Classes
    Molecule
  7. val _model: Model

    Internal Model representation of molecule.

    Internal Model representation of molecule.

    Molecule transforms custom boilerplate DSL constructs to Datomic queries in 3 steps:

    Custom DSL molecule --> Model --> Query --> Datomic query string

    Definition Classes
    Molecule09MoleculeBase
  8. val _nestedQuery: Option[Query]

    Internal optional Query representation of nested molecule with added entity search for each level.

    Internal optional Query representation of nested molecule with added entity search for each level.

    Molecule transforms custom boilerplate DSL constructs to Datomic queries in 3 steps:

    Custom DSL molecule --> Model --> Query --> Datomic query string

    Definition Classes
    Molecule09MoleculeBase
  9. val _query: Query

    Internal Query representation of molecule.

    Internal Query representation of molecule.

    Molecule transforms custom boilerplate DSL constructs to Datomic queries in 3 steps:

    Custom DSL molecule --> Model --> Query --> Datomic query string

    Definition Classes
    Molecule09MoleculeBase
  10. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  11. final def cast(value: Any): String
    Attributes
    protected
    Definition Classes
    Helpers
  12. def castAggrLazySeq[T](row: List[_], i: Int): T
    Attributes
    protected
    Definition Classes
    CastHelpers
  13. def castAggrLazySeqBigDecimal(row: List[_], i: Int): BigDecimal
    Attributes
    protected
    Definition Classes
    CastHelpers
  14. def castAggrLazySeqBigInt(row: List[_], i: Int): BigInt
    Attributes
    protected
    Definition Classes
    CastHelpers
  15. def castAggrLazySeqDouble(row: List[_], i: Int): Float
    Attributes
    protected
    Definition Classes
    CastHelpers
  16. def castAggrLazySeqInt(row: List[_], i: Int): Int
    Attributes
    protected
    Definition Classes
    CastHelpers
  17. def castAggrListHashSet[T](row: List[_], i: Int): List[T]
    Attributes
    protected
    Definition Classes
    CastHelpers
  18. def castAggrListHashSetBigDecimal(row: List[_], i: Int): List[BigDecimal]
    Attributes
    protected
    Definition Classes
    CastHelpers
  19. def castAggrListHashSetBigInt(row: List[_], i: Int): List[BigInt]
    Attributes
    protected
    Definition Classes
    CastHelpers
  20. def castAggrListHashSetFloat(row: List[_], i: Int): List[Float]
    Attributes
    protected
    Definition Classes
    CastHelpers
  21. def castAggrListHashSetInt(row: List[_], i: Int): List[Int]
    Attributes
    protected
    Definition Classes
    CastHelpers
  22. def castAggrListLazySeq[T](row: List[_], i: Int): List[T]
    Attributes
    protected
    Definition Classes
    CastHelpers
  23. def castAggrListLazySeqBigDecimal(row: List[_], i: Int): List[BigDecimal]
    Attributes
    protected
    Definition Classes
    CastHelpers
  24. def castAggrListLazySeqBigInt(row: List[_], i: Int): List[BigInt]
    Attributes
    protected
    Definition Classes
    CastHelpers
  25. def castAggrListLazySeqFloat(row: List[_], i: Int): List[Float]
    Attributes
    protected
    Definition Classes
    CastHelpers
  26. def castAggrListLazySeqInt(row: List[_], i: Int): List[Int]
    Attributes
    protected
    Definition Classes
    CastHelpers
  27. def castAggrListVector[T](row: List[_], i: Int): List[T]
    Attributes
    protected
    Definition Classes
    CastHelpers
  28. def castAggrListVectorBigDecimal(row: List[_], i: Int): List[BigDecimal]
    Attributes
    protected
    Definition Classes
    CastHelpers
  29. def castAggrListVectorBigInt(row: List[_], i: Int): List[BigInt]
    Attributes
    protected
    Definition Classes
    CastHelpers
  30. def castAggrListVectorFloat(row: List[_], i: Int): List[Float]
    Attributes
    protected
    Definition Classes
    CastHelpers
  31. def castAggrListVectorInt(row: List[_], i: Int): List[Int]
    Attributes
    protected
    Definition Classes
    CastHelpers
  32. def castAggrVector[T](row: List[_], i: Int): T
    Attributes
    protected
    Definition Classes
    CastHelpers
  33. def castAggrVectorBigDecimal(row: List[_], i: Int): BigDecimal
    Attributes
    protected
    Definition Classes
    CastHelpers
  34. def castAggrVectorBigInt(row: List[_], i: Int): BigInt
    Attributes
    protected
    Definition Classes
    CastHelpers
  35. def castAggrVectorDouble(row: List[_], i: Int): Float
    Attributes
    protected
    Definition Classes
    CastHelpers
  36. def castAggrVectorInt(row: List[_], i: Int): Int
    Attributes
    protected
    Definition Classes
    CastHelpers
  37. def castMany[T](row: List[_], i: Int): Set[T]
    Attributes
    protected
    Definition Classes
    CastHelpers
  38. def castManyBigDecimal(row: List[_], i: Int): Set[BigDecimal]
    Attributes
    protected
    Definition Classes
    CastHelpers
  39. def castManyBigInt(row: List[_], i: Int): Set[BigInt]
    Attributes
    protected
    Definition Classes
    CastHelpers
  40. def castManyEnum(row: List[_], i: Int): Set[String]
    Attributes
    protected
    Definition Classes
    CastHelpers
  41. def castManyFloat(row: List[_], i: Int): Set[Float]
    Attributes
    protected
    Definition Classes
    CastHelpers
  42. def castManyInt(row: List[_], i: Int): Set[Int]
    Attributes
    protected
    Definition Classes
    CastHelpers
  43. def castMapBigDecimal(row: List[_], i: Int): Map[String, BigDecimal]
    Attributes
    protected
    Definition Classes
    CastHelpers
  44. def castMapBigInt(row: List[_], i: Int): Map[String, BigInt]
    Attributes
    protected
    Definition Classes
    CastHelpers
  45. def castMapBoolean(row: List[_], i: Int): Map[String, Boolean]
    Attributes
    protected
    Definition Classes
    CastHelpers
  46. def castMapDate(row: List[_], i: Int): Map[String, Date]
    Attributes
    protected
    Definition Classes
    CastHelpers
  47. def castMapDouble(row: List[_], i: Int): Map[String, Double]
    Attributes
    protected
    Definition Classes
    CastHelpers
  48. def castMapFloat(row: List[_], i: Int): Map[String, Float]
    Attributes
    protected
    Definition Classes
    CastHelpers
  49. def castMapInt(row: List[_], i: Int): Map[String, Int]
    Attributes
    protected
    Definition Classes
    CastHelpers
  50. def castMapLong(row: List[_], i: Int): Map[String, Long]
    Attributes
    protected
    Definition Classes
    CastHelpers
  51. def castMapString(row: List[_], i: Int): Map[String, String]
    Attributes
    protected
    Definition Classes
    CastHelpers
  52. def castMapURI(row: List[_], i: Int): Map[String, URI]
    Attributes
    protected
    Definition Classes
    CastHelpers
  53. def castMapUUID(row: List[_], i: Int): Map[String, UUID]
    Attributes
    protected
    Definition Classes
    CastHelpers
  54. def castOne[T](row: List[_], i: Int): T
    Attributes
    protected
    Definition Classes
    CastHelpers
  55. def castOneBigDecimal(row: List[_], i: Int): BigDecimal
    Attributes
    protected
    Definition Classes
    CastHelpers
  56. def castOneBigInt(row: List[_], i: Int): BigInt
    Attributes
    protected
    Definition Classes
    CastHelpers
  57. def castOneFloat(row: List[_], i: Int): Float
    Attributes
    protected
    Definition Classes
    CastHelpers
  58. def castOneInt(row: List[_], i: Int): Int
    Attributes
    protected
    Definition Classes
    CastHelpers
  59. def castOptMany[T](row: List[_], i: Int): Option[Set[T]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  60. def castOptManyApply[T](row: List[_], i: Int): Option[Set[T]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  61. def castOptManyApplyBigDecimal(row: List[_], i: Int): Option[Set[BigDecimal]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  62. def castOptManyApplyBigInt(row: List[_], i: Int): Option[Set[BigInt]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  63. def castOptManyApplyDouble(row: List[_], i: Int): Option[Set[Double]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  64. def castOptManyApplyFloat(row: List[_], i: Int): Option[Set[Float]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  65. def castOptManyApplyInt(row: List[_], i: Int): Option[Set[Int]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  66. def castOptManyApplyLong(row: List[_], i: Int): Option[Set[Long]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  67. def castOptManyBigDecimal(row: List[_], i: Int): Option[Set[BigDecimal]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  68. def castOptManyBigInt(row: List[_], i: Int): Option[Set[BigInt]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  69. def castOptManyDouble(row: List[_], i: Int): Option[Set[Double]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  70. def castOptManyEnum(row: List[_], i: Int): Option[Set[String]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  71. def castOptManyFloat(row: List[_], i: Int): Option[Set[Float]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  72. def castOptManyInt(row: List[_], i: Int): Option[Set[Int]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  73. def castOptManyLong(row: List[_], i: Int): Option[Set[Long]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  74. def castOptManyRefAttr(row: List[_], i: Int): Option[Set[Long]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  75. def castOptMapApplyBigDecimal(row: List[_], i: Int): Option[Map[String, BigDecimal]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  76. def castOptMapApplyBigInt(row: List[_], i: Int): Option[Map[String, BigInt]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  77. def castOptMapApplyBoolean(row: List[_], i: Int): Option[Map[String, Boolean]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  78. def castOptMapApplyDate(row: List[_], i: Int): Option[Map[String, Date]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  79. def castOptMapApplyDouble(row: List[_], i: Int): Option[Map[String, Double]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  80. def castOptMapApplyFloat(row: List[_], i: Int): Option[Map[String, Float]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  81. def castOptMapApplyInt(row: List[_], i: Int): Option[Map[String, Int]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  82. def castOptMapApplyLong(row: List[_], i: Int): Option[Map[String, Long]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  83. def castOptMapApplyString(row: List[_], i: Int): Option[Map[String, String]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  84. def castOptMapApplyURI(row: List[_], i: Int): Option[Map[String, URI]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  85. def castOptMapApplyUUID(row: List[_], i: Int): Option[Map[String, UUID]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  86. def castOptMapBigDecimal(row: List[_], i: Int): Option[Map[String, BigDecimal]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  87. def castOptMapBigInt(row: List[_], i: Int): Option[Map[String, BigInt]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  88. def castOptMapBoolean(row: List[_], i: Int): Option[Map[String, Boolean]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  89. def castOptMapDate(row: List[_], i: Int): Option[Map[String, Date]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  90. def castOptMapDouble(row: List[_], i: Int): Option[Map[String, Double]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  91. def castOptMapFloat(row: List[_], i: Int): Option[Map[String, Float]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  92. def castOptMapInt(row: List[_], i: Int): Option[Map[String, Int]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  93. def castOptMapLong(row: List[_], i: Int): Option[Map[String, Long]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  94. def castOptMapString(row: List[_], i: Int): Option[Map[String, String]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  95. def castOptMapURI(row: List[_], i: Int): Option[Map[String, URI]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  96. def castOptMapUUID(row: List[_], i: Int): Option[Map[String, UUID]]
    Attributes
    protected
    Definition Classes
    CastHelpers
  97. def castOptOne[T](row: List[_], i: Int): Option[T]
    Attributes
    protected
    Definition Classes
    CastHelpers
  98. def castOptOneApply[T](row: List[_], i: Int): Option[T]
    Attributes
    protected
    Definition Classes
    CastHelpers
  99. def castOptOneApplyBigDecimal(row: List[_], i: Int): Option[BigDecimal]
    Attributes
    protected
    Definition Classes
    CastHelpers
  100. def castOptOneApplyBigInt(row: List[_], i: Int): Option[BigInt]
    Attributes
    protected
    Definition Classes
    CastHelpers
  101. def castOptOneApplyDouble(row: List[_], i: Int): Option[Double]
    Attributes
    protected
    Definition Classes
    CastHelpers
  102. def castOptOneApplyFloat(row: List[_], i: Int): Option[Float]
    Attributes
    protected
    Definition Classes
    CastHelpers
  103. def castOptOneApplyInt(row: List[_], i: Int): Option[Int]
    Attributes
    protected
    Definition Classes
    CastHelpers
  104. def castOptOneApplyLong(row: List[_], i: Int): Option[Long]
    Attributes
    protected
    Definition Classes
    CastHelpers
  105. def castOptOneBigDecimal(row: List[_], i: Int): Option[BigDecimal]
    Attributes
    protected
    Definition Classes
    CastHelpers
  106. def castOptOneBigInt(row: List[_], i: Int): Option[BigInt]
    Attributes
    protected
    Definition Classes
    CastHelpers
  107. def castOptOneDouble(row: List[_], i: Int): Option[Double]
    Attributes
    protected
    Definition Classes
    CastHelpers
  108. def castOptOneEnum(row: List[_], i: Int): Option[String]
    Attributes
    protected
    Definition Classes
    CastHelpers
  109. def castOptOneFloat(row: List[_], i: Int): Option[Float]
    Attributes
    protected
    Definition Classes
    CastHelpers
  110. def castOptOneInt(row: List[_], i: Int): Option[Int]
    Attributes
    protected
    Definition Classes
    CastHelpers
  111. def castOptOneLong(row: List[_], i: Int): Option[Long]
    Attributes
    protected
    Definition Classes
    CastHelpers
  112. def castOptOneRefAttr(row: List[_], i: Int): Option[Long]
    Attributes
    protected
    Definition Classes
    CastHelpers
  113. def castRow(row: List[AnyRef]): (A, B, C, D, E, F, G, H, I)
    Attributes
    protected
    Definition Classes
    CastHelpers
  114. def clone(): AnyRef
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @native() @throws( ... )
  115. final def date(s: String): Date
    Attributes
    protected
    Definition Classes
    Helpers
  116. def debugGet(implicit conn: Conn): Unit

    Debug call to get on a molecule (without affecting the db).

    Debug call to get on a molecule (without affecting the db).

    Prints the following to output:

    1. Internal molecule transformation representations:
    Molecule DSL --> Model --> Query --> Datomic query

    2. Data returned from get query (max 500 rows).

    conn

    Implicit Conn value in scope

    Definition Classes
    ShowDebug
  117. def debugGetAsOf(date: Date)(implicit conn: Conn): Unit

    Debug call to getAsOf(date) on a molecule (without affecting the db).

    Debug call to getAsOf(date) on a molecule (without affecting the db).

    Prints the following to output:

    1. Internal molecule transformation representations:
    Molecule DSL --> Model --> Query --> Datomic query

    2. Data returned from get query (max 500 rows).

    conn

    Implicit Conn value in scope

    Definition Classes
    ShowDebug
  118. def debugGetAsOf(tx: TxReport)(implicit conn: Conn): Unit

    Debug call to getAsOf(tx) on a molecule (without affecting the db).

    Debug call to getAsOf(tx) on a molecule (without affecting the db).

    Prints the following to output:

    1. Internal molecule transformation representations:
    Molecule DSL --> Model --> Query --> Datomic query

    2. Data returned from get query (max 500 rows).

    tx

    TxReport

    conn

    Implicit Conn value in scope

    Definition Classes
    ShowDebug
  119. def debugGetAsOf(t: Long)(implicit conn: Conn): Unit

    Debug call to getAsOf(t) on a molecule (without affecting the db).

    Debug call to getAsOf(t) on a molecule (without affecting the db).

    Prints the following to output:

    1. Internal molecule transformation representations:
    Molecule DSL --> Model --> Query --> Datomic query

    2. Data returned from get query (max 500 rows).

    conn

    Implicit Conn value in scope

    Definition Classes
    ShowDebug
  120. def debugGetHistory(implicit conn: Conn): Unit

    Debug call to getHistory on a molecule (without affecting the db).

    Debug call to getHistory on a molecule (without affecting the db).

    Prints the following to output:

    1. Internal molecule transformation representations:
    Molecule DSL --> Model --> Query --> Datomic query

    2. Data returned from get query (max 500 rows).

    conn

    Implicit Conn value in scope

    Definition Classes
    ShowDebug
  121. def debugGetSince(date: Date)(implicit conn: Conn): Unit

    Debug call to getSince(date) on a molecule (without affecting the db).

    Debug call to getSince(date) on a molecule (without affecting the db).

    Prints the following to output:

    1. Internal molecule transformation representations:
    Molecule DSL --> Model --> Query --> Datomic query

    2. Data returned from get query (max 500 rows).

    conn

    Implicit Conn value in scope

    Definition Classes
    ShowDebug
  122. def debugGetSince(tx: TxReport)(implicit conn: Conn): Unit

    Debug call to getSince(tx) on a molecule (without affecting the db).

    Debug call to getSince(tx) on a molecule (without affecting the db).

    Prints the following to output:

    1. Internal molecule transformation representations:
    Molecule DSL --> Model --> Query --> Datomic query

    2. Data returned from get query (max 500 rows).

    tx

    TxReport

    conn

    Implicit Conn value in scope

    Definition Classes
    ShowDebug
  123. def debugGetSince(t: Long)(implicit conn: Conn): Unit

    Debug call to getSince(t) on a molecule (without affecting the db).

    Debug call to getSince(t) on a molecule (without affecting the db).

    Prints the following to output:

    1. Internal molecule transformation representations:
    Molecule DSL --> Model --> Query --> Datomic query

    2. Data returned from get query (max 500 rows).

    conn

    Implicit Conn value in scope

    Definition Classes
    ShowDebug
  124. def debugGetWith(txData: List[List[_]])(implicit conn: Conn): Unit

    Debug call to getWith(txData) on a molecule (without affecting the db).

    Debug call to getWith(txData) on a molecule (without affecting the db).

    Prints the following to output:

    1. Internal molecule transformation representations:
    Molecule DSL --> Model --> Query --> Datomic query

    2. Data returned from get query (max 500 rows).

    3. Transactions of applied transaction data.

    txData

    Raw transaction data as java.util.List[Object]

    conn

    Implicit Conn value in scope

    Definition Classes
    ShowDebug
  125. def debugGetWith(txMolecules: Seq[Seq[Statement]]*)(implicit conn: Conn): Unit

    Debug call to getWith(txMolecules) on a molecule (without affecting the db).

    Debug call to getWith(txMolecules) on a molecule (without affecting the db).

    Prints the following to output:

    1. Internal molecule transformation representations:
    Molecule DSL --> Model --> Query --> Datomic query

    2. Data returned from get query (max 500 rows).

    3. Transactions of applied transaction molecules.

    txMolecules

    Transaction statements from applied Molecules with test data

    conn

    Implicit Conn value in scope

    Definition Classes
    ShowDebug
  126. def debugSave(implicit conn: Conn): Unit

    Debug call to save on a molecule (without affecting the db).

    Debug call to save on a molecule (without affecting the db).

    Prints internal molecule transformation representations to output:

    Model --> Generic statements --> Datomic statements

    conn

    Implicit Conn value in scope

    returns

    Unit

    Definition Classes
    ShowDebug
  127. def debugUpdate(implicit conn: Conn): Unit

    Debug call to update on a molecule (without affecting the db).

    Debug call to update on a molecule (without affecting the db).

    Prints internal molecule transformation representations to output:

    Model --> Generic statements --> Datomic statements

    conn

    Implicit Conn value in scope

    Definition Classes
    ShowDebug
  128. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  129. def equals(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  130. final def f(a: Any): Any
    Attributes
    protected
    Definition Classes
    Helpers
  131. final def f2(a: Any): Any
    Attributes
    protected
    Definition Classes
    Helpers
  132. def finalize(): Unit
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  133. final def format(date: Date): String
    Attributes
    protected
    Definition Classes
    Helpers
  134. final def format2(date: Date): String
    Attributes
    protected
    Definition Classes
    Helpers
  135. def get(n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of n rows as tuples matching molecule.

    Get List of n rows as tuples matching molecule.

    Only n rows are type-casted.

    Person.name.age.get(1) === List(
      ("Ben", 42)
    )

    Since retrieving a List is considered the default fetch format, the getter method is simply named get (and not getList).

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of types matching the attributes of the molecule

    Definition Classes
    GetList
  136. def get(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of all rows as tuples matching molecule.

    Get List of all rows as tuples matching molecule.

    Person.name.age.get === List(
      ("Ben", 42),
      ("Liz", 37),
    )

    Since retrieving a List is considered the default fetch format, the getter method is simply named get (and not getList).

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of types matching the attributes of the molecule

    Definition Classes
    GetList
  137. def getArray(n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of n rows as tuples matching molecule.

    Get Array of n rows as tuples matching molecule.

    Person.name.age.getArray(1) === Array(
      ("Ben", 42)
    )



    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    The Array is only populated with n rows of type-casted tuples.

    n

    Number of rows

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of types matching the attributes of the molecule

    Definition Classes
    GetArray
  138. def getArray(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of all rows as tuples matching molecule.

    Get Array of all rows as tuples matching molecule.

    Person.name.age.getArray === Array(
      ("Ben", 42),
      ("Liz", 37),
    )



    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of types matching the attributes of the molecule

    Definition Classes
    GetArray
  139. def getArrayAsOf(date: Date, n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of n rows as tuples matching molecule as of date.

    Get Array of n rows as tuples matching molecule as of date.

    Get data at a human point in time (a java.util.Date).

    val beforeInsert = new java.util.Date
    
    // Insert
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    )
    val List(ben, liz) = tx1.eids
    val afterInsert = new java.util.Date
    
    // Update
    val tx2 = Person(ben).age(43).update
    val afterUpdate = new java.util.Date
    
    // Get Array of all rows as of afterUpdate
    Person.name.age.getArrayAsOf(afterUpdate) === Array(
      ("Ben", 43),
      ("Liz", 37)
    )
    
    // Get Array of n rows as of afterUpdate
    Person.name.age.getArrayAsOf(afterUpdate, 1) === Array(
      ("Ben", 43)
    )

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    The Array is only populated with n rows of type-casted tuples.

    date

    java.util.Date

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual on getAsOf

  140. def getArrayAsOf(date: Date)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of all rows as tuples matching molecule as of date.

    Get Array of all rows as tuples matching molecule as of date.

    Get data at a human point in time (a java.util.Date).

    val beforeInsert = new java.util.Date
    
    // Insert
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    )
    val List(ben, liz) = tx1.eids
    val afterInsert = new java.util.Date
    
    // Update
    val tx2 = Person(ben).age(43).update
    val afterUpdate = new java.util.Date
    
    // Retract
    val tx3 = ben.retract
    val afterRetract = new java.util.Date
    
    // No data yet before insert
    Person.name.age.getArrayAsOf(beforeInsert) === Array()
    
    // Get Array of all rows as of afterInsert
    Person.name.age.getArrayAsOf(afterInsert) === Array(
      ("Ben", 42),
      ("Liz", 37)
    )
    
    // Get Array of all rows as of afterUpdate
    Person.name.age.getArrayAsOf(afterUpdate) === Array(
      ("Ben", 43), // Ben now 43
      ("Liz", 37)
    )
    
    // Get Array of all rows as of afterRetract
    Person.name.age.getArrayAsOf(afterRetract) === Array(
      ("Liz", 37) // Ben gone
    )

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    date

    java.util.Date

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual on getAsOf

  141. def getArrayAsOf(tx: TxReport, n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of n rows as tuples matching molecule as of tx.

    Get Array of n rows as tuples matching molecule as of tx.

    Datomic's internal asOf method can take a transaction entity id as argument to retrieve a database value as of that transaction (including).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Insert (tx report 1)
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    )
    val List(ben, liz) = tx1.eids
    
    // Update (tx report 2)
    val tx2 = Person(ben).age(43).update
    
    // Get Array of all rows as of tx2 (after update)
    Person.name.age.getArrayAsOf(tx2) === Array(
      ("Ben", 43),
      ("Liz", 37)
    )
    
    // Get Array of n rows as of tx2 (after update)
    Person.name.age.getArrayAsOf(tx2, 1) === Array(
      ("Ben", 43)
    )

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    The Array is only populated with n rows of type-casted tuples.

    tx

    TxReport (returned from all molecule transaction operations)

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual on getAsOf

  142. def getArrayAsOf(tx: TxReport)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of all rows as tuples matching molecule as of tx.

    Get Array of all rows as tuples matching molecule as of tx.

    Datomic's internal asOf method can take a transaction entity id as argument to retrieve a database value as of that transaction (including).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Insert (tx report 1)
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    )
    val List(ben, liz) = tx1.eids
    
    // Update (tx report 2)
    val tx2 = Person(ben).age(43).update
    
    // Retract (tx report 3)
    val tx3 = ben.retract
    
    // Get Array of all rows as of tx1 (after insert)
    Person.name.age.getArrayAsOf(tx1) === Array(
      ("Ben", 42),
      ("Liz", 37)
    )
    
    // Get Array of all rows as of tx2 (after update)
    Person.name.age.getArrayAsOf(tx2) === Array(
      ("Ben", 43), // Ben now 43
      ("Liz", 37)
    )
    
    // Get Array of all rows as of tx3 (after retract)
    Person.name.age.getArrayAsOf(tx3) === Array(
      ("Liz", 37) // Ben gone
    )

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    tx

    TxReport (returned from all molecule transaction operations)

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual on getAsOf

  143. def getArrayAsOf(t: Long, n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of n rows as tuples matching molecule as of transaction time t.

    Get Array of n rows as tuples matching molecule as of transaction time t.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved in a getHistory call for an attribute and then be used to get data as of that point in time (including that transaction):

    // Insert (t 1028)
    val List(ben, liz) = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    ) eids
    
    // Update (t 1031)
    Person(ben).age(43).update
    
    // History of Ben
    Person(ben).age.t.op.getHistory.sortBy(r => (r._2, r._3)) === List(
      (42, 1028, true),  // Insert:  42 asserted
      (42, 1031, false), // Update:  42 retracted
      (43, 1031, true),  //          43 asserted
    )
    
    // Get Array of all rows as of transaction t 1031 (after update)
    Person.name.age.getArrayAsOf(1031) === Array(
      ("Ben", 43),
      ("Liz", 37)
    )
    
    // Get Array of n rows as of transaction t 1031 (after update)
    Person.name.age.getArrayAsOf(1031, 1) === Array(
      ("Ben", 43)
    )

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    The Array is only populated with n rows of type-casted tuples.

    t

    Long Transaction time t

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual on getAsOf

  144. def getArrayAsOf(t: Long)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of all rows as tuples matching molecule as of transaction time t.

    Get Array of all rows as tuples matching molecule as of transaction time t.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved in a getHistory call for an attribute and then be used to get data as of that point in time (including that transaction):

    // Insert (t 1028)
    val List(ben, liz) = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    ) eids
    
    // Update (t 1031)
    Person(ben).age(43).update
    
    // Retract (t 1032)
    ben.retract
    
    // History of Ben
    Person(ben).age.t.op.getHistory.sortBy(r => (r._2, r._3)) === List(
      (42, 1028, true),  // Insert:  42 asserted
      (42, 1031, false), // Update:  42 retracted
      (43, 1031, true),  //          43 asserted
      (43, 1032, false)  // Retract: 43 retracted
    )
    
    // Get Array of data as of transaction t 1028 (after insert)
    Person.name.age.getArrayAsOf(1028) === Array(
      ("Ben", 42),
      ("Liz", 37)
    )
    
    // Get Array of all rows as of transaction t 1031 (after update)
    Person.name.age.getArrayAsOf(1031) === Array(
      ("Ben", 43),
      ("Liz", 37)
    )
    
    // Get Array of all rows as of transaction t 1032 (after retract)
    Person.name.age.getArrayAsOf(1032) === Array(
      ("Liz", 37)
    )

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    t

    Transaction time t

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual on getAsOf

  145. def getArraySince(date: Date, n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of n rows as tuples matching molecule since date.

    Get Array of n rows as tuples matching molecule since date.

    Get data added/retracted since a human point in time (a java.util.Date).

    // Transact 3 times (`inst` retrieves transaction time/Date from tx report)
    val date1 = Person.name("Ann").save.inst
    val date2 = Person.name("Ben").save.inst
    val date3 = Person.name("Cay").save.inst
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since date1
    Person.name.getArraySince(date1) === Array("Ben", "Cay")
    
    // Ben and Cay added since date1 - only n (1) rows returned
    Person.name.getArraySince(date1, 1) === Array("Ben")

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    The Array is only populated with n rows of type-casted tuples.

    date

    java.util.Date

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual on since

  146. def getArraySince(date: Date)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of all rows as tuples matching molecule since date.

    Get Array of all rows as tuples matching molecule since date.

    Get data added/retracted since a human point in time (a java.util.Date).

    // Transact 3 times (`inst` retrieves transaction time/Date from tx report)
    val date1 = Person.name("Ann").save.inst
    val date2 = Person.name("Ben").save.inst
    val date3 = Person.name("Cay").save.inst
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since date1
    Person.name.getArraySince(date1) === Array("Ben", "Cay")
    
    // Cay added since date2
    Person.name.getArraySince(date2) === Array("Cay")
    
    // Nothing added since date3
    Person.name.getArraySince(date3) === Nil

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    date

    java.util.Date

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual on since

  147. def getArraySince(tx: TxReport, n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of n rows as tuples matching molecule since tx.

    Get Array of n rows as tuples matching molecule since tx.

    Datomic's internal since can take a transaction entity id as argument to retrieve a database value since that transaction (excluding the transaction itself).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Get tx reports for 3 transactions
    val tx1 = Person.name("Ann").save
    val tx2 = Person.name("Ben").save
    val tx3 = Person.name("Cay").save
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since tx1
    Person.name.getArraySince(tx1) === Array("Ben", "Cay")
    
    // Ben and Cay added since tx1 - only n (1) rows returned
    Person.name.getArraySince(tx1, 1) === Array("Ben")

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    The Array is only populated with n rows of type-casted tuples.

    tx

    TxReport

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual on since

  148. def getArraySince(tx: TxReport)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of all rows as tuples matching molecule since tx.

    Get Array of all rows as tuples matching molecule since tx.

    Datomic's internal since can take a transaction entity id as argument to retrieve a database value since that transaction (excluding the transaction itself).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Get tx reports for 3 transactions
    val tx1 = Person.name("Ann").save
    val tx2 = Person.name("Ben").save
    val tx3 = Person.name("Cay").save
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since tx1
    Person.name.getArraySince(tx1) === Array("Ben", "Cay")
    
    // Cay added since tx2
    Person.name.getArraySince(tx2) === Array("Cay")
    
    // Nothing added since tx3
    Person.name.getArraySince(tx3) === Nil

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    tx

    TxReport

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual on since

  149. def getArraySince(t: Long, n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of n rows as tuples matching molecule since transaction time t.

    Get Array of n rows as tuples matching molecule since transaction time t.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved by calling t on the tx report returned from transactional operations and then be used to get data since that point in time (excluding that transaction):

    // 3 transaction times `t`
    val t1 = Person.name("Ann").save.t
    val t2 = Person.name("Ben").save.t
    val t3 = Person.name("Cay").save.t
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since transaction time t 1028
    Person.name.getArraySince(t1) === Array("Ben", "Cay")
    
    // Ben and Cay added since transaction time t 1028 - only n (1) rows returned
    Person.name.getArraySince(t1, 1) === Array("Ben")

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    The Array is only populated with n rows of type-casted tuples.

    t

    Transaction time t

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual on since

  150. def getArraySince(t: Long)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of all rows as tuples matching molecule since transaction time t.

    Get Array of all rows as tuples matching molecule since transaction time t.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved by calling t on the tx report returned from transactional operations and then be used to get data since that point in time (excluding that transaction):

    // 3 transaction times `t`
    val t1 = Person.name("Ann").save.t
    val t2 = Person.name("Ben").save.t
    val t3 = Person.name("Cay").save.t
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since transaction time t 1028
    Person.name.getArraySince(t1) === Array("Ben", "Cay")
    
    // Cay added since transaction time t 1030
    Person.name.getArraySince(t2) === Array("Cay")
    
    // Nothing added since transaction time t 1032
    Person.name.getArraySince(t3) === Nil

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    t

    Transaction time t

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual on since

  151. def getArrayWith(txData: List[_], n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of n rows as tuples matching molecule with applied raw transaction data.

    Get Array of n rows as tuples matching molecule with applied raw transaction data.

    Apply raw transaction data to in-memory "branch" of db without affecting db to see how it would then look:

    // Live size of Person db
    Person.name.get.size === 150
    
    // Read some transaction data from file
    val data_rdr2 = new FileReader("examples/resources/seattle/seattle-data1a.dtm")
    val newDataTx = Util.readAll(data_rdr2).get(0).asInstanceOf[java.util.List[Object]]
    
    // Imagine future db - 100 persons would be added, apparently
    Person.name.getArrayWith(newDataTx).size === 250
    
    // Imagine future db - Let's just take 10
    Person.name.getArrayWith(newDataTx, 10).size === 10

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    The Array is only populated with n rows of type-casted tuples.

    txData

    Raw transaction data as java.util.List[Object]

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual

  152. def getArrayWith(txData: List[_])(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of all rows as tuples matching molecule with applied raw transaction data.

    Get Array of all rows as tuples matching molecule with applied raw transaction data.

    Apply raw transaction data to in-memory "branch" of db without affecting db to see how it would then look:

    // Live size of Person db
    Person.name.get.size === 150
    
    // Read some transaction data from file
    val data_rdr2 = new FileReader("examples/resources/seattle/seattle-data1a.dtm")
    val newDataTx = Util.readAll(data_rdr2).get(0).asInstanceOf[java.util.List[Object]]
    
    // Imagine future db - 100 persons would be added, apparently
    Person.name.getArrayWith(newDataTx).size === 250

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    txData

    Raw transaction data as java.util.List[Object]

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual

  153. def getArrayWith(n: Int, txMolecules: Seq[Seq[Statement]]*)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of n rows as tuples matching molecule with applied molecule transaction data.

    Get Array of n rows as tuples matching molecule with applied molecule transaction data.

    Apply one or more molecule transactions to in-memory "branch" of db without affecting db to see how it would then look:

    // Current state
    val List(ben, liz) = Person.name.likes.insert(
      ("Ben", "pasta"),
      ("Liz", "pizza")
    ).eids
    
    // Test multiple transactions
    Person.name.likes.getArrayWith(
      Person(ben).likes("sushi").getUpdateTx,
      Person(liz).likes("cake").getUpdateTx
    ) === Array(
      ("Ben", "sushi")
      ("Liz", "cake")
    )
    
    // Same as above, but only n (1) rows returned:
    Person.name.likes.getArrayWith(
      1
      Person(ben).likes("sushi").getUpdateTx,
      Person(liz).likes("cake").getUpdateTx
    ) === Array(
      ("Ben", "sushi")
    )

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    The Array is only populated with n rows of type-casted tuples.

    n

    Int Number of rows returned

    txMolecules

    Transaction statements from applied Molecules with test data

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    Note

    Note how the n parameter has to come before the txMolecules vararg.

    See also

    Manual

  154. def getArrayWith(txMolecules: Seq[Seq[Statement]]*)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Array[(A, B, C, D, E, F, G, H, I)]

    Get Array of all rows as tuples matching molecule with applied molecule transaction data.

    Get Array of all rows as tuples matching molecule with applied molecule transaction data.

    Apply one or more molecule transactions to in-memory "branch" of db without affecting db to see how it would then look:

    // Current state
    val ben = Person.name("Ben").likes("pasta").save.eid
    
    // Base data
    Person.name.likes.getArrayWith(
      // apply imaginary transaction data
      Person(ben).likes("sushi").getUpdateTx
    ) === Array(
      // Effect: Ben would like sushi if tx was applied
      ("Ben", "sushi")
    )
    
    // Current state is still the same
    Person.name.likes.get === Array(
      ("Ben", "pasta")
    )

    Multiple transactions can be applied to test more complex what-if scenarios!

    Getting a pre-allocated Array populated with typed data is the fastest way to query Datomic with Molecule. Looping the Array in a while loop with a mutable index pointer will also be the fastest way to traverse the data set.

    txMolecules

    Transaction statements from applied Molecules with test data

    conn

    Implicit Conn value in scope

    returns

    Array[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetArray
    See also

    Manual

  155. def getAsOf(date: Date, n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of n rows as tuples matching molecule as of date.

    Get List of n rows as tuples matching molecule as of date.

    Get data at a human point in time (a java.util.Date).

    val beforeInsert = new java.util.Date
    
    // Insert
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    )
    val List(ben, liz) = tx1.eids
    val afterInsert = new java.util.Date
    
    // Update
    val tx2 = Person(ben).age(43).update
    val afterUpdate = new java.util.Date
    
    // Get List of all rows as of afterUpdate
    Person.name.age.getAsOf(afterUpdate) === List(
      ("Ben", 43),
      ("Liz", 37)
    )
    
    // Get List of n rows as of afterUpdate
    Person.name.age.getAsOf(afterUpdate, 1) === List(
      ("Ben", 43)
    )
    date

    java.util.Date

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual on getAsOf

  156. def getAsOf(date: Date)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of all rows as tuples matching molecule as of date.

    Get List of all rows as tuples matching molecule as of date.

    Get data at a human point in time (a java.util.Date).

    val beforeInsert = new java.util.Date
    
    // Insert
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37),
    )
    val List(ben, liz) = tx1.eids
    val afterInsert = new java.util.Date
    
    // Update
    val tx2 = Person(ben).age(43).update
    val afterUpdate = new java.util.Date
    
    // Retract
    val tx3 = ben.retract
    val afterRetract = new java.util.Date
    
    // No data yet before insert
    Person.name.age.getAsOf(beforeInsert) === Nil
    
    // Get List of all rows as of afterInsert
    Person.name.age.getAsOf(afterInsert) === List(
      ("Ben", 42),
      ("Liz", 37)´
    )
    
    // Get List of all rows as of afterUpdate
    Person.name.age.getAsOf(afterUpdate) === List(
      ("Ben", 43), // Ben now 43
      ("Liz", 37)
    )
    
    // Get List of all rows as of afterRetract
    Person.name.age.getAsOf(afterRetract) === List(
      ("Liz", 37) // Ben gone
    )
    date

    java.util.Date

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual on getAsOf

  157. def getAsOf(tx: TxReport, n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of n rows as tuples matching molecule as of tx.

    Get List of n rows as tuples matching molecule as of tx.

    Datomic's internal asOf method can take a transaction entity id as argument to retrieve a database value as of that transaction (including).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Insert (tx report 1)
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    )
    val List(ben, liz) = tx1.eids
    
    // Update (tx report 2)
    val tx2 = Person(ben).age(43).update
    
    // Current data
    Person.name.age.get === List(
      ("Ben", 43),
      ("Liz", 37)
    )
    
    // Get List of all rows as of tx2 (after update)
    Person.name.age.getAsOf(tx2) === List(
      ("Ben", 43),
      ("Liz", 37)
    )
    
    // Get List of n rows as of tx2 (after update)
    Person.name.age.getAsOf(tx2, 1) === List(
      ("Ben", 43)
    )
    tx

    TxReport (returned from all molecule transaction operations)

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual on getAsOf

  158. def getAsOf(tx: TxReport)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of all rows as tuples matching molecule as of tx.

    Get List of all rows as tuples matching molecule as of tx.

    Datomic's internal asOf method can take a transaction entity id as argument to retrieve a database value as of that transaction (including).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Insert (tx report 1)
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37),
    )
    val List(ben, liz) = tx1.eids
    
    // Update (tx report 2)
    val tx2 = Person(ben).age(43).update
    
    // Retract (tx report 3)
    val tx3 = ben.retract
    
    // Get List of all rows as of tx1 (after insert)
    Person.name.age.getAsOf(tx1) === List(
      ("Ben", 42),
      ("Liz", 37)
    )
    
    // Get List of all rows as of tx2 (after update)
    Person.name.age.getAsOf(tx2) === List(
      ("Ben", 43), // Ben now 43
      ("Liz", 37)
    )
    
    // Get List of all rows as of tx3 (after retract)
    Person.name.age.getAsOf(tx3) === List(
      ("Liz", 37) // Ben gone
    )
    tx

    TxReport (returned from all molecule transaction operations)

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual on getAsOf

  159. def getAsOf(t: Long, n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of n rows as tuples matching molecule as of transaction time t.

    Get List of n rows as tuples matching molecule as of transaction time t.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved in a getHistory call for an attribute and then be used to get data as of that point in time (including that transaction):

    // Insert (t 1028)
    val List(ben, liz) = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37),
    ) eids
    
    // Update (t 1031)
    Person(ben).age(43).update
    
    // History of Ben
    Person(ben).age.t.op.getHistory.sortBy(r => (r._2, r._3)) === List(
      (42, 1028, true),  // Insert:  42 asserted
      (42, 1031, false), // Update:  42 retracted
      (43, 1031, true),  //          43 asserted
    )
    
    // Get List of all all rows as of transaction t 1031 (after update)
    Person.name.age.getAsOf(1031) === List(
      ("Ben", 43),
      ("Liz", 37)
    )
    
    // Get List of n rows as of transaction t 1031 (after update)
    Person.name.age.getAsOf(1031, 1) === List(
      ("Ben", 43)
    )
    t

    Long Transaction time t

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual on getAsOf

  160. def getAsOf(t: Long)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of all rows as tuples matching molecule as of transaction time t.

    Get List of all rows as tuples matching molecule as of transaction time t.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved in a getHistory call for an attribute and then be used to get data as of that point in time (including that transaction):

    // Insert (t 1028)
    val List(ben, liz) = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37),
    ) eids
    
    // Update (t 1031)
    Person(ben).age(43).update
    
    // Retract (t 1032)
    ben.retract
    
    // History of Ben
    Person(ben).age.t.op.getHistory.sortBy(r => (r._2, r._3)) === List(
      (42, 1028, true),  // Insert:  42 asserted
      (42, 1031, false), // Update:  42 retracted
      (43, 1031, true),  //          43 asserted
      (43, 1032, false)  // Retract: 43 retracted
    )
    
    // Get List of all rows as of transaction t 1028 (after insert)
    Person.name.age.getAsOf(1028) === List(
      ("Liz", 37),
      ("Ben", 42)
    )
    
    // Get List of all rows as of transaction t 1031 (after update)
    Person.name.age.getAsOf(1031) === List(
      ("Liz", 37),
      ("Ben", 43)
    )
    
    // Get List of all rows as of transaction t 1032 (after retract)
    Person.name.age.getAsOf(1032) === List(
      ("Liz", 37)
    )
    t

    Transaction time t

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual on getAsOf

  161. final def getClass(): Class[_]
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  162. def getHistory(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get history of operations as List on an attribute in the db.

    Get history of operations as List on an attribute in the db.

    Generic datom attributes that can be called when getHistory is called:

    e - Entity id
    a - Attribute name
    v - Attribute value
    ns - Namespace name
    tx - TxReport
    t - Transaction time t
    txInstant - Transaction time as java.util.Date
    op - Operation: true (add) or false (retract)

    Example:

    // Insert (t 1028)
    val List(ben, liz) = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37),
    ) eids
    
    // Update (t 1031)
    Person(ben).age(43).update
    
    // Retract (t 1032)
    ben.retract
    
    // History of Ben
    Person(ben).age.t.op.getHistory.sortBy(r => (r._2, r._3)) === List(
      (42, 1028, true),  // Insert:  42 asserted
      (42, 1031, false), // Update:  42 retracted
      (43, 1031, true),  //          43 asserted
      (43, 1032, false)  // Retract: 43 retracted
    )
    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    manual for more info on generic attributes.

  163. def getIterable(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Iterable[(A, B, C, D, E, F, G, H, I)]

    Get Iterable of all rows as tuples matching the molecule.

    Get Iterable of all rows as tuples matching the molecule.

    Rows are lazily type-casted on each call to iterator.next().

    Person.name.age.getIterable.toList === List(
      ("Ben", 42),
      ("Liz", 37),
    )
    conn

    Implicit Conn value in scope

    returns

    Iterable[Tpl] where Tpl is a tuple of types matching the attributes of the molecule

    Definition Classes
    GetIterable
  164. def getIterableAsOf(date: Date)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Iterable[(A, B, C, D, E, F, G, H, I)]

    Get Iterable of all rows as tuples matching molecule as of date.

    Get Iterable of all rows as tuples matching molecule as of date.

    Get data at a human point in time (a java.util.Date).

    val beforeInsert = new java.util.Date
    
    // Insert
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    )
    val List(ben, liz) = tx1.eids
    val afterInsert = new java.util.Date
    
    // Update
    val tx2 = Person(ben).age(43).update
    val afterUpdate = new java.util.Date
    
    // Retract
    val tx3 = ben.retract
    val afterRetract = new java.util.Date
    
    // Get Iterable of all rows as of beforeInsert
    val iterable0: Iterable[(String, Int)] = Person.name.age.getIterableAsOf(beforeInsert)
    val iterator0: Iterator[(String, Int)] = iterable0.iterator
    iterator0.hasNext === false // Nothing yet
    
    // Get Iterable of all rows as of afterInsert
    val iterable1: Iterable[(String, Int)] = Person.name.age.getIterableAsOf(afterInsert)
    val iterator1: Iterator[(String, Int)] = iterable1.iterator
    
    // Type casting lazily performed with each call to `next`
    iterator1.next === ("Ben", 42)
    iterator1.next === ("Liz", 37)
    
    // Get Iterable of all rows as of afterUpdate
    val iterable2: Iterable[(String, Int)] = Person.name.age.getIterableAsOf(afterUpdate)
    val iterator2: Iterator[(String, Int)] = iterable2.iterator
    
    // Type casting lazily performed with each call to `next`
    iterator2.next === ("Ben", 43) // Ben now 43
    iterator2.next === ("Liz", 37)
    
    // Get Iterable of all rows as of afterRetract
    val iterable3: Iterable[(String, Int)] = Person.name.age.getIterableAsOf(afterRetract)
    val iterator3: Iterator[(String, Int)] = iterable3.iterator
    
    // Type casting lazily performed with each call to `next`
    iterator3.next === ("Liz", 37)
    iterator3.hasNext === false // Ben gone
    date

    java.util.Date

    conn

    Implicit Conn value in scope

    returns

    Iterable[Tpl] where Tpl is tuple of data matching molecule

    Definition Classes
    GetIterable
    See also

    Manual on getAsOf

  165. def getIterableAsOf(tx: TxReport)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Iterable[(A, B, C, D, E, F, G, H, I)]

    Get Iterable of all rows as tuples matching molecule as of tx.

    Get Iterable of all rows as tuples matching molecule as of tx.

    Datomic's internal asOf method can take a transaction entity id as argument to retrieve a database value as of that transaction (including).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Insert (tx report 1)
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    )
    val List(ben, liz) = tx1.eids
    
    // Update (tx report 2)
    val tx2 = Person(ben).age(43).update
    
    // Retract (tx report 3)
    val tx3 = ben.retract
    
    // Get Iterable of all rows as of tx1 (after insert)
    val iterable1: Iterable[(String, Int)] = Person.name.age.getIterableAsOf(tx1)
    val iterator1: Iterator[(String, Int)] = iterable1.iterator
    
    // Type casting lazily performed with each call to `next`
    iterator1.next === ("Ben", 42)
    iterator1.next === ("Liz", 37)
    
    // Get Iterable of all rows as of tx2 (after update)
    val iterable2: Iterable[(String, Int)] = Person.name.age.getIterableAsOf(tx2)
    val iterator2: Iterator[(String, Int)] = iterable2.iterator
    
    // Type casting lazily performed with each call to `next`
    iterator2.next === ("Ben", 43) // Ben now 43
    iterator2.next === ("Liz", 37)
    
    // Get Iterable of all rows as of tx3 (after retract)
    val iterable3: Iterable[(String, Int)] = Person.name.age.getIterableAsOf(tx3)
    val iterator3: Iterator[(String, Int)] = iterable3.iterator
    
    // Type casting lazily performed with each call to `next`
    iterator3.next === ("Liz", 37)
    iterator3.hasNext === false // Ben gone
    tx

    TxReport (returned from all molecule transaction operations)

    conn

    Implicit Conn value in scope

    returns

    Iterable[Tpl] where Tpl is tuple of data matching molecule

    Definition Classes
    GetIterable
    See also

    Manual on getAsOf

  166. def getIterableAsOf(t: Long)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Iterable[(A, B, C, D, E, F, G, H, I)]

    Get Iterable of all rows as tuples matching molecule as of transaction time t.

    Get Iterable of all rows as tuples matching molecule as of transaction time t.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    Call getIterableAsOf for large result sets to maximize runtime performance. Data is lazily type-casted on each call to next on the iterator.

    t can for instance be retrieved in a getHistory call for an attribute and then be used to get data as of that point in time (including that transaction):

    // Insert (t 1028)
    val List(ben, liz) = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    ) eids
    
    // Update (t 1031)
    Person(ben).age(43).update
    
    // Retract (t 1032)
    ben.retract
    
    // History of Ben
    Person(ben).age.t.op.getHistory.sortBy(r => (r._2, r._3)) === List(
      (42, 1028, true),  // Insert:  42 asserted
      (42, 1031, false), // Update:  42 retracted
      (43, 1031, true),  //          43 asserted
      (43, 1032, false)  // Retract: 43 retracted
    )
    
    // Get Iterable of all rows as of transaction t 1028 (after insert)
    val iterable1: Iterable[(String, Int)] = Person.name.age.getIterableAsOf(1028)
    val iterator1: Iterator[(String, Int)] = iterable1.iterator
    
    // Type casting lazily performed with each call to `next`
    iterator1.next === ("Liz", 37)
    iterator1.next === ("Ben", 42)
    
    // Get Iterable of all rows as of transaction t 1031 (after update)
    val iterable2: Iterable[(String, Int)] = Person.name.age.getIterableAsOf(1031)
    val iterator2: Iterator[(String, Int)] = iterable2.iterator
    
    // Type casting lazily performed with each call to `next`
    iterator2.next === ("Liz", 37)
    iterator2.next === ("Ben", 43) // Ben now 43
    
    // Get Iterable of all rows as of transaction t 1032 (after retract)
    val iterable3: Iterable[(String, Int)] = Person.name.age.getIterableAsOf(1032)
    val iterator3: Iterator[(String, Int)] = iterable3.iterator
    
    // Type casting lazily performed with each call to `next`
    iterator3.next === ("Liz", 37)
    iterator3.hasNext === false // Ben gone
    t

    Transaction time t

    conn

    Implicit Conn value in scope

    returns

    Iterable[Tpl] where Tpl is tuple of data matching molecule

    Definition Classes
    GetIterable
    See also

    Manual on getAsOf

  167. def getIterableSince(date: Date)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Iterable[(A, B, C, D, E, F, G, H, I)]

    Get Iterable of all rows as tuples matching molecule since date.

    Get Iterable of all rows as tuples matching molecule since date.

    Get data added/retracted since a human point in time (a java.util.Date).

    // Transact 3 times (`inst` retrieves transaction time from tx report)
    val date1 = Person.name("Ann").save.inst
    val date2 = Person.name("Ben").save.inst
    val date3 = Person.name("Cay").save.inst
    
    // Current values
    Person.name.getIterable.iterator.toList === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since date1
    Person.name.getIterableSince(date1).iterator.toList === List("Ben", "Cay")
    
    // Cay added since date2
    Person.name.getIterableSince(date2).iterator.toList === List("Cay")
    
    // Nothing added since date3
    Person.name.getIterableSince(date3).iterator.toList === Nil
    date

    java.util.Date

    conn

    Implicit Conn value in scope

    returns

    Iterable[Tpl] where Tpl is tuple of data matching molecule

    Definition Classes
    GetIterable
    See also

    Manual on since

  168. def getIterableSince(tx: TxReport)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Iterable[(A, B, C, D, E, F, G, H, I)]

    Get Iterable of all rows as tuples matching molecule since tx.

    Get Iterable of all rows as tuples matching molecule since tx.

    Datomic's internal since method can take a transaction entity id as argument to retrieve a database value since that transaction (excluding the transaction itself).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Get tx reports for 3 transactions
    val tx1 = Person.name("Ann").save
    val tx2 = Person.name("Ben").save
    val tx3 = Person.name("Cay").save
    
    // Current values
    Person.name.getIterable.iterator.toList === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since tx1
    Person.name.getIterableSince(tx1).iterator.toList === List("Ben", "Cay")
    
    // Cay added since tx2
    Person.name.getIterableSince(tx2).iterator.toList === List("Cay")
    
    // Nothing added since tx3
    Person.name.getIterableSince(tx3).iterator.toList === Nil
    tx

    TxReport

    conn

    Implicit Conn value in scope

    returns

    Iterable[Tpl] where Tpl is tuple of data matching molecule

    Definition Classes
    GetIterable
    See also

    Manual on since

  169. def getIterableSince(t: Long)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Iterable[(A, B, C, D, E, F, G, H, I)]

    Get Iterable of all rows as tuples matching molecule since transaction time t.

    Get Iterable of all rows as tuples matching molecule since transaction time t.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    Call getIterableSince for large result sets to maximize runtime performance. Data is lazily type-casted on each call to next on the iterator.

    t can for instance be retrieved calling t on the tx report returned from transactional operations and then be used to get data since that point in time (excluding that transaction):

    // 3 transaction times `t`
    val t1 = Person.name("Ann").save.t
    val t2 = Person.name("Ben").save.t
    val t3 = Person.name("Cay").save.t
    
    // Current values as Iterable
    Person.name.getIterable.iterator.toList === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since transaction time t1
    Person.name.getIterableSince(t1).iterator.toList === List("Ben", "Cay")
    
    // Cay added since transaction time t2
    Person.name.getIterableSince(t2).iterator.toList === List("Cay")
    
    // Nothing added since transaction time t3
    Person.name.getIterableSince(t3).iterator.toList === Nil
    t

    Transaction time t

    conn

    Implicit Conn value in scope

    returns

    Iterable[Tpl] where Tpl is tuple of data matching molecule

    Definition Classes
    GetIterable
    See also

    Manual on since

  170. def getIterableWith(txData: List[_])(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Iterable[(A, B, C, D, E, F, G, H, I)]

    Get Iterable of all rows as tuples matching molecule with applied raw transaction data.

    Get Iterable of all rows as tuples matching molecule with applied raw transaction data.

    Apply raw transaction data to in-memory "branch" of db without affecting db to see how it would then look:

    // Live size of Person db
    Person.name.get.size === 150
    
    // Read some transaction data from file
    val data_rdr2 = new FileReader("examples/resources/seattle/seattle-data1a.dtm")
    val newDataTx = Util.readAll(data_rdr2).get(0).asInstanceOf[java.util.List[Object]]
    
    // Imagine future db - 100 persons would be added, apparently
    Person.name.getIterableWith(newDataTx).size === 250
    txData

    Raw transaction data as java.util.List[Object]

    conn

    Implicit Conn value in scope

    returns

    Iterable of molecule data

    Definition Classes
    GetIterable
    See also

    Manual

  171. def getIterableWith(txMolecules: Seq[Seq[Statement]]*)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): Iterable[(A, B, C, D, E, F, G, H, I)]

    Get Iterable of all rows as tuples matching molecule with applied molecule transaction data.

    Get Iterable of all rows as tuples matching molecule with applied molecule transaction data.

    Apply one or more molecule transactions to in-memory "branch" of db without affecting db to see how it would then look:

    // Current state
    val ben = Person.name("Ben").likes("pasta").save.eid
    
    // Base data
    Person.name.likes.getIterableWith(
      // apply imaginary transaction data
      Person(ben).likes("sushi").getUpdateTx
    ).iterator.toList === List(
      // Effect: Ben would like sushi if tx was applied
      ("Ben", "sushi")
    )
    
    // Current state is still the same
    Person.name.likes.get === List(
      ("Ben", "pasta")
    )

    Multiple transactions can be applied to test more complex what-if scenarios!

    txMolecules

    Transaction statements from applied Molecules with test data

    conn

    Implicit Conn value in scope

    returns

    Iterable of molecule data

    Definition Classes
    GetIterable
    See also

    Manual

  172. def getJson(n: Int)(implicit conn: Conn): String

    Get json data for n rows matching molecule

    Get json data for n rows matching molecule

    Person.name.age.getJson(1) ===
      """[
        |{"person.name": "Ben", "person.age": 42}
        |]""".stripMargin



    Namespace.Attribute is used as json fields. Values are quoted when necessary. Nested data becomes json objects etc.

    n

    Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual on getJson

  173. def getJson(implicit conn: Conn): String

    Get json data for all rows matching molecule.

    Get json data for all rows matching molecule.

    Person.name.age.getJson ===
      """[
        |{"person.name": "Ben", "person.age": 42},
        |{"person.name": "Liz", "person.age": 37}
        |]""".stripMargin



    Namespace.Attribute is used as json fields. Values are quoted when necessary. Nested data becomes json objects etc.

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual on getJson

  174. def getJsonAsOf(date: Date, n: Int)(implicit conn: Conn): String

    Get json data for n rows matching molecule as of tx.

    Get json data for n rows matching molecule as of tx.

    Get data at a human point in time (a java.util.Date).

    val beforeInsert = new java.util.Date
    
    // Insert
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    )
    val List(ben, liz) = tx1.eids
    val afterInsert = new java.util.Date
    
    // Update
    val tx2 = Person(ben).age(43).update
    val afterUpdate = new java.util.Date
    
    // Get List of all rows as of afterUpdate
    Person.name.age.getJsonAsOf(afterUpdate) ===
      """[
        |{"person.name": "Ben", "person.age": 43},
        |{"person.name": "Liz", "person.age": 37}
        |]""".stripMargin
    
    // Get List of n rows as of afterUpdate
    Person.name.age.getJsonAsOf(afterUpdate, 1) ===
      """[
        |{"person.name": "Ben", "person.age": 43}
        |]""".stripMargin
    date

    java.util.Date

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual on getAsOf

  175. def getJsonAsOf(date: Date)(implicit conn: Conn): String

    Get json data for all rows matching molecule as of date.

    Get json data for all rows matching molecule as of date.

    Get data at a human point in time (a java.util.Date).

    val beforeInsert = new java.util.Date
    
    // Insert
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37),
    )
    val List(ben, liz) = tx1.eids
    val afterInsert = new java.util.Date
    
    // Update
    val tx2 = Person(ben).age(43).update
    val afterUpdate = new java.util.Date
    
    // Retract
    val tx3 = ben.retract
    val afterRetract = new java.util.Date
    
    // No data yet before insert
    Person.name.age.getJsonAsOf(beforeInsert) === ""
    
    // Get List of all rows as of afterInsert
    Person.name.age.getJsonAsOf(afterInsert) ===
      """[
        |{"person.name": "Ben", "person.age": 42},
        |{"person.name": "Liz", "person.age": 37}
        |]""".stripMargin
    
    // Get List of all rows as of afterUpdate
    Person.name.age.getJsonAsOf(afterUpdate) ===
      """[
        |{"person.name": "Ben", "person.age": 43},
        |{"person.name": "Liz", "person.age": 37}
        |]""".stripMargin
    
    // Get List of all rows as of afterRetract
    Person.name.age.getJsonAsOf(afterRetract) ===
      """[
        |{"person.name": "Liz", "person.age": 37}
        |]""".stripMargin
    date

    java.util.Date

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual on getAsOf

  176. def getJsonAsOf(tx: TxReport, n: Int)(implicit conn: Conn): String

    Get json data for n rows matching molecule as of tx.

    Get json data for n rows matching molecule as of tx.

    Datomic's internal asOf method can take a transaction entity id as argument to retrieve a database value as of that transaction (including).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Insert (tx report 1)
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    )
    val List(ben, liz) = tx1.eids
    
    // Update (tx report 2)
    val tx2 = Person(ben).age(43).update
    
    // Get json for all rows as of transaction tx2 (after update) - Ben now 43
    Person.name.age.getJsonAsOf(tx2) ===
      """[
        |{"person.name": "Ben", "person.age": 43},
        |{"person.name": "Liz", "person.age": 37}
        |]""".stripMargin
    
    // Get json for n rows as of transaction tx2 (after update) - Ben now 43
    Person.name.age.getJsonAsOf(tx2, 1) ===
      """[
        |{"person.name": "Ben", "person.age": 43}
        |]""".stripMargin
    tx

    TxReport (returned from all molecule transaction operations)

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual on getAsOf

  177. def getJsonAsOf(tx: TxReport)(implicit conn: Conn): String

    Get json data for all rows matching molecule as of tx.

    Get json data for all rows matching molecule as of tx.

    Datomic's internal asOf method can take a transaction entity id as argument to retrieve a database value as of that transaction (including).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Insert (tx report 1)
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    )
    val List(ben, liz) = tx1.eids
    
    // Update (tx report 2)
    val tx2 = Person(ben).age(43).update
    
    // Retract (tx report 3)
    val tx3 = ben.retract
    
    // Get json for all rows as of transaction tx1 (after insert)
    Person.name.age.getJsonAsOf(tx1) ===
      """[
        |{"person.name": "Ben", "person.age": 42},
        |{"person.name": "Liz", "person.age": 37}
        |]""".stripMargin
    
    // Get json for all rows as of transaction tx2 (after update) - Ben now 43
    Person.name.age.getJsonAsOf(tx2) ===
      """[
        |{"person.name": "Ben", "person.age": 43},
        |{"person.name": "Liz", "person.age": 37}
        |]""".stripMargin
    
    // Get json for all rows as of transaction tx3 (after retract) - Ben gone
    Person.name.age.getJsonAsOf(tx3) ===
      """[
        |{"person.name": "Liz", "person.age": 37}
        |]""".stripMargin
    tx

    TxReport (returned from all molecule transaction operations)

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual on getAsOf

  178. def getJsonAsOf(t: Long, n: Int)(implicit conn: Conn): String

    Get json data for n rows matching molecule as of transaction time t.

    Get json data for n rows matching molecule as of transaction time t.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved in a getHistory call for an attribute and then be used to get data as of that point in time (including that transaction):

    // Insert (t 1028)
    val List(ben, liz) = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    ) eids
    
    // Update (t 1031)
    Person(ben).age(43).update
    
    // History of Ben
    Person(ben).age.t.op.getHistory.sortBy(r => (r._2, r._3)) === List(
      (42, 1028, true),  // Insert:  42 asserted
      (42, 1031, false), // Update:  42 retracted
      (43, 1031, true),  //          43 asserted
    )
    
    // Get json for all rows as of transaction t 1031 (after update)
    Person.name.age.getJsonAsOf(1031) ===
      """[
        |{"person.name": "Ben", "person.age": 43},
        |{"person.name": "Liz", "person.age": 37}
        |]""".stripMargin
    
    // Get json for n (1) rows as of transaction t 1031 (after update)
    Person.name.age.getJsonAsOf(1031, 1) ===
      """[
        |{"person.name": "Ben", "person.age": 43}
        |]""".stripMargin
    t

    Transaction time t

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual on getAsOf

  179. def getJsonAsOf(t: Long)(implicit conn: Conn): String

    Get json data for all rows matching molecule as of transaction time t.

    Get json data for all rows matching molecule as of transaction time t.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved in a getHistory call for an attribute and then be used to get data as of that point in time (including that transaction):

    // Insert (t 1028)
    val List(ben, liz) = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37)
    ) eids
    
    // Update (t 1031)
    Person(ben).age(43).update
    
    // Retract (t 1032)
    ben.retract
    
    // History of Ben
    Person(ben).age.t.op.getHistory.sortBy(r => (r._2, r._3)) === List(
      (42, 1028, true),  // Insert:  42 asserted
      (42, 1031, false), // Update:  42 retracted
      (43, 1031, true),  //          43 asserted
      (43, 1032, false)  // Retract: 43 retracted
    )
    
    // Get json for all rows as of transaction t 1028 (after insert)
    Person.name.age.getJsonAsOf(1028) ===
      """[
        |{"person.name": "Ben", "person.age": 42},
        |{"person.name": "Liz", "person.age": 37}
        |]""".stripMargin
    
    // Get json for all rows as of transaction t 1031 (after update) - Ben now 43
    Person.name.age.getJsonAsOf(1031) ===
      """[
        |{"person.name": "Ben", "person.age": 43},
        |{"person.name": "Liz", "person.age": 37}
        |]""".stripMargin
    
    // Get json for all rows as of transaction t 1032 (after retract) - Ben gone
    Person.name.age.getJsonAsOf(1032) ===
      """[
        |{"person.name": "Liz", "person.age": 37}
        |]""".stripMargin
    t

    Transaction time t

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual on getAsOf

  180. def getJsonComposite(conn: Conn, n: Int): String
    Attributes
    protected
    Definition Classes
    GetJson
  181. def getJsonFlat(conn: Conn, n: Int): String
    Attributes
    protected
    Definition Classes
    GetJson
  182. def getJsonSince(date: Date, n: Int)(implicit conn: Conn): String

    Get json data for n rows matching molecule since date.

    Get json data for n rows matching molecule since date.

    Get data added/retracted since a human point in time (a java.util.Date).

    // Transact 3 times (`inst` retrieves transaction time/Date from tx report)
    val date1 = Person.name("Ann").save.inst
    val date2 = Person.name("Ben").save.inst
    val date3 = Person.name("Cay").save.inst
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since date1
    Person.name.getJsonSince(date1) ===
      """[
        |{"person.name": "Ben"},
        |{"person.name": "Cay"}
        |]""".stripMargin
    
    // Ben and Cay added since date1 - only n (1) rows returned
    Person.name.getJsonSince(date1, 1) ===
      """[
        |{"person.name": "Ben"}
        |]""".stripMargin
    date

    java.util.Date

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual on since

  183. def getJsonSince(date: Date)(implicit conn: Conn): String

    Get json data for all rows matching molecule since date.

    Get json data for all rows matching molecule since date.

    Get data added/retracted since a human point in time (a java.util.Date).

    // Transact 3 times (`inst` retrieves transaction time/Date from tx report)
    val date1 = Person.name("Ann").save.inst
    val date2 = Person.name("Ben").save.inst
    val date3 = Person.name("Cay").save.inst
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since date1
    Person.name.getJsonSince(date1) ===
      """[
        |{"person.name": "Ben"},
        |{"person.name": "Cay"}
        |]""".stripMargin
    
    // Cay added since date2
    Person.name.getJsonSince(date2) ===
      """[
        |{"person.name": "Cay"}
        |]""".stripMargin
    
    // Nothing added since date3
    Person.name.getJsonSince(date3) === ""
    date

    java.util.Date

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual on since

  184. def getJsonSince(tx: TxReport, n: Int)(implicit conn: Conn): String

    Get json data for n rows matching molecule since tx.

    Get json data for n rows matching molecule since tx.

    Datomic's internal since can take a transaction entity id as argument to retrieve a database value since that transaction (excluding the transaction itself).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Get tx reports for 3 transactions
    val tx1 = Person.name("Ann").save
    val tx2 = Person.name("Ben").save
    val tx3 = Person.name("Cay").save
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since tx1
    Person.name.getJsonSince(tx1) ===
      """[
        |{"person.name": "Ben"},
        |{"person.name": "Cay"}
        |]""".stripMargin
    
    // Ben and Cay added since tx1 - only n (1) rows returned
    Person.name.getJsonSince(tx1, 1) ===
      """[
        |{"person.name": "Ben"}
        |]""".stripMargin
    tx

    TxReport (returned from all molecule transaction operations)

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual on getAsOf

  185. def getJsonSince(tx: TxReport)(implicit conn: Conn): String

    Get json data for all rows matching molecule since tx.

    Get json data for all rows matching molecule since tx.

    Datomic's internal since can take a transaction entity id as argument to retrieve a database value since that transaction (excluding the transaction itself).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Get tx reports for 3 transactions
    val tx1 = Person.name("Ann").save
    val tx2 = Person.name("Ben").save
    val tx3 = Person.name("Cay").save
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since tx1
    Person.name.getJsonSince(tx1) ===
      """[
        |{"person.name": "Ben"},
        |{"person.name": "Cay"}
        |]""".stripMargin
    
    // Cay added since tx2
    Person.name.getJsonSince(tx2) ===
      """[
        |{"person.name": "Cay"}
        |]""".stripMargin
    
    // Nothing added since tx3
    Person.name.getJsonSince(tx3) === ""
    tx

    TxReport (returned from all molecule transaction operations)

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual on getAsOf

  186. def getJsonSince(t: Long, n: Int)(implicit conn: Conn): String

    Get json data for n rows matching molecule since transaction time t.

    Get json data for n rows matching molecule since transaction time t.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved by calling t on the tx report returned from transactional operations and then be used to get data since that point in time (excluding that transaction):

    // 3 transaction times `t`
    val t1 = Person.name("Ann").save.t
    val t2 = Person.name("Ben").save.t
    val t3 = Person.name("Cay").save.t
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since transaction time t 1028
    Person.name.getJsonSince(t1) ===
      """[
        |{"person.name": "Ben"},
        |{"person.name": "Cay"}
        |]""".stripMargin
    
    // Ben and Cay added since transaction time t 1028 - only n (1) rows returned
    Person.name.getJsonSince(t1, 1) ===
      """[
        |{"person.name": "Ben"}
        |]""".stripMargin
    t

    Transaction time t

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual on getAsOf

  187. def getJsonSince(t: Long)(implicit conn: Conn): String

    Get json data for all rows matching molecule since transaction time t.

    Get json data for all rows matching molecule since transaction time t.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved by calling t on the tx report returned from transactional operations and then be used to get data since that point in time (excluding that transaction):

    // 3 transaction times `t`
    val t1 = Person.name("Ann").save.t
    val t2 = Person.name("Ben").save.t
    val t3 = Person.name("Cay").save.t
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since transaction time t 1028
    Person.name.getJsonSince(t1) ===
      """[
        |{"person.name": "Ben"},
        |{"person.name": "Cay"}
        |]""".stripMargin
    
    // Cay added since transaction time t 1030
    Person.name.getJsonSince(t2) ===
      """[
        |{"person.name": "Cay"}
        |]""".stripMargin
    
    // Nothing added since transaction time t 1032
    Person.name.getJsonSince(t3) === ""
    t

    Transaction time t

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual on getAsOf

  188. def getJsonWith(txData: List[_], n: Int)(implicit conn: Conn): String

    Get json data for n rows matching molecule with applied raw transaction data.

    Get json data for n rows matching molecule with applied raw transaction data.

    Apply raw transaction data to in-memory "branch" of db without affecting db to see how it would then look:

    // Live size of Person db
    Person.name.get.size === 150
    
    // Read some transaction data from file
    val data_rdr2 = new FileReader("examples/resources/seattle/seattle-data1a.dtm")
    val newDataTx = Util.readAll(data_rdr2).get(0).asInstanceOf[java.util.List[Object]]
    
    // Imagine future db - 100 persons would be added, apparently
    Person.name.getJsonWith(newDataTx).size === 250
    
    // Imagine future db - Let's just take 10
    Person.name.getJsonWith(newDataTx, 10).size === 10
    txData

    Raw transaction data as java.util.List[Object]

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetJson
    See also

    Manual

  189. def getJsonWith(txData: List[_])(implicit conn: Conn): String

    Get json data for all rows matching molecule with applied raw transaction data.

    Get json data for all rows matching molecule with applied raw transaction data.

    Apply raw transaction data to in-memory "branch" of db without affecting db to see how it would then look:

    // Live size of Person db
    Person.name.get.size === 150
    
    // Read some transaction data from file
    val data_rdr2 = new FileReader("examples/resources/seattle/seattle-data1a.dtm")
    val newDataTx = Util.readAll(data_rdr2).get(0).asInstanceOf[java.util.List[Object]]
    
    // Imagine future db - 100 persons would be added, apparently
    Person.name.getJsonWith(newDataTx).size === 250
    txData

    Raw transaction data as java.util.List[Object]

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetJson
    See also

    Manual

  190. def getJsonWith(n: Int, txMolecules: Seq[Seq[Statement]]*)(implicit conn: Conn): String

    Get json data for all rows matching molecule with applied molecule transaction data.

    Get json data for all rows matching molecule with applied molecule transaction data.

    Apply one or more molecule transactions to in-memory "branch" of db without affecting db to see how it would then look:

    // Current state
    val List(ben, liz) = Person.name.likes.insert(
      ("Ben", "pasta"),
      ("Liz", "pizza")
    ).eids
    
    // Test multiple transactions
    Person.name.likes.getJsonWith(
      Person(ben).likes("sushi").getUpdateTx,
      Person(liz).likes("cake").getUpdateTx
    ) ===
      """[
        |{"person.name": "Ben", "person.likes": "sushi"},
        |{"person.name": "Liz", "person.likes": "cake"}
        |]""".stripMargin
    
    // Same as above, but only n (1) rows returned:
    Person.name.likes.getJsonWith(
      1
      Person(ben).likes("sushi").getUpdateTx,
      Person(liz).likes("cake").getUpdateTx
    ) ===
      """[
        |{"person.name": "Ben", "person.likes": "sushi"}
        |]""".stripMargin

    Multiple transactions can be applied to test more complex what-if scenarios!

    txMolecules

    Transaction statements from applied Molecules with test data

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual

  191. def getJsonWith(txMolecules: Seq[Seq[Statement]]*)(implicit conn: Conn): String

    Get json data for all rows matching molecule with applied molecule transaction data.

    Get json data for all rows matching molecule with applied molecule transaction data.

    Apply one or more molecule transactions to in-memory "branch" of db without affecting db to see how it would then look:

    // Current state
    val ben = Person.name("Ben").likes("pasta").save.eid
    
    // Base data
    Person.name.likes.getJsonWith(
      // apply imaginary transaction data
      Person(ben).likes("sushi").getUpdateTx
    ) ===
      """[
        |{"person.name": "Ben", "person.likes": "sushi"}
        |]""".stripMargin
    
    // Current state is still the same
    Person.name.likes.get === List(("Ben", "pasta"))

    Multiple transactions can be applied to test more complex what-if scenarios!

    txMolecules

    Transaction statements from applied Molecules with test data

    conn

    Implicit Conn value in scope

    returns

    String of json

    Definition Classes
    GetJson
    See also

    Manual

  192. def getRaw(n: Int)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of n untyped rows matching molecule.

    Get java.util.Collection of n untyped rows matching molecule.

    Person.name.age.getRaw(1).toString === """[["Ben" 42]]"""
    n

    Number of rows

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
  193. def getRaw(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of all untyped rows matching molecule.

    Get java.util.Collection of all untyped rows matching molecule.

    Person.name.age.getRaw.toString === """[["Ben" 42], ["Liz" 37]]"""
    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
  194. def getRawAsOf(date: Date, n: Int)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of n untyped rows matching molecule as of date.

    Get java.util.Collection of n untyped rows matching molecule as of date.

    Call getRawAsOf when data doesn't need to be type-casted. Datomic's raw data is returned as-is.

    Get data at a human point in time (a java.util.Date).

    val beforeInsert = new java.util.Date
    
    // Insert
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37),
    )
    val ben = tx1.eid
    val afterInsert = new java.util.Date
    
    // Update
    val tx2 = Person(ben).age(43).update
    val afterUpdate = new java.util.Date
    
    // Retract
    val tx3 = ben.retract
    val afterRetract = new java.util.Date
    
    // Get all rows of raw data as of beforeInsert
    Person.name.age.getRawAsOf(beforeInsert).toString === """[]"""
    
    // Get all rows of raw data as of afterInsert
    Person.name.age.getRawAsOf(afterInsert).toString === """[["Liz" 37], ["Ben" 42]]"""
    
    // Get n (1) rows of raw data as of afterInsert
    Person.name.age.getRawAsOf(afterInsert, 1).toString === """[["Liz" 37]]"""
    date

    java.util.Date

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual on getAsOf

  195. def getRawAsOf(date: Date)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of all untyped rows matching molecule as of date.

    Get java.util.Collection of all untyped rows matching molecule as of date.

    Call getRawAsOf when data doesn't need to be type-casted. Datomic's raw data is returned as-is.

    Get data at a human point in time (a java.util.Date).

    val beforeInsert = new java.util.Date
    
    // Insert
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37),
    )
    val ben = tx1.eid
    val afterInsert = new java.util.Date
    
    // Update
    val tx2 = Person(ben).age(43).update
    val afterUpdate = new java.util.Date
    
    // Retract
    val tx3 = ben.retract
    val afterRetract = new java.util.Date
    
    // Get raw data as of beforeInsert
    Person.name.age.getRawAsOf(beforeInsert).toString === """[]"""
    
    // Get raw data as of afterInsert
    Person.name.age.getRawAsOf(afterInsert).toString === """[["Liz" 37], ["Ben" 42]]"""
    
    // Get raw data as of afterUpdate
    Person.name.age.getRawAsOf(afterUpdate).toString === """[["Liz" 37], ["Ben" 43]]""" // Ben now 43
    
    // Get raw data as of afterRetract
    Person.name.age.getRawAsOf(afterRetract).toString === """[["Liz" 37]]""" // Ben gone
    date

    java.util.Date

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual on getAsOf

  196. def getRawAsOf(tx: TxReport, n: Int)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of n untyped rows matching molecule as of tx.

    Get java.util.Collection of n untyped rows matching molecule as of tx.

    The Array is only populated with n rows of type-casted tuples. Call getRawAsOf when data doesn't need to be type-casted. Datomic's raw data is returned as-is.

    Datomic's internal asOf method can take a transaction entity id as argument to retrieve a database value as of that transaction (including).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Insert (tx report 1)
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37),
    )
    val ben = tx1.eid
    
    // Update (tx report 2)
    val tx2 = Person(ben).age(43).update
    
    // Retract (tx report 3)
    val tx3 = ben.retract
    
    // Get all rows of raw data as of tx1 (after insert)
    Person.name.age.getRawAsOf(tx1).toString === """[["Liz" 37], ["Ben" 42]]"""
    
    // Get n (1) rows of raw data as of tx1 (after insert)
    Person.name.age.getRawAsOf(tx1, 1).toString === """[["Liz" 37]]"""
    tx

    TxReport (returned from all molecule transaction operations)

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual on getAsOf

  197. def getRawAsOf(tx: TxReport)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of all untyped rows matching molecule as of tx.

    Get java.util.Collection of all untyped rows matching molecule as of tx.

    Call getRawAsOf when data doesn't need to be type-casted. Datomic's raw data is returned as-is.

    Datomic's internal asOf method can take a transaction entity id as argument to retrieve a database value as of that transaction (including).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Insert (tx report 1)
    val tx1 = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37),
    )
    val ben = tx1.eid
    
    // Update (tx report 2)
    val tx2 = Person(ben).age(43).update
    
    // Retract (tx report 3)
    val tx3 = ben.retract
    
    // Get raw data as of tx1 (after insert)
    Person.name.age.getRawAsOf(tx1).toString === """[["Liz" 37], ["Ben" 42]]"""
    
    // Get raw data as of tx2 (after update)
    Person.name.age.getRawAsOf(tx2).toString === """[["Liz" 37], ["Ben" 43]]""" // Ben now 43
    
    // Get raw data as of tx3 (after retract)
    Person.name.age.getRawAsOf(tx3).toString === """[["Liz" 37]]""" // Ben gone
    tx

    TxReport (returned from all molecule transaction operations)

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual on getAsOf

  198. def getRawAsOf(t: Long, n: Int)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of n untyped rows matching molecule as of transaction time t.

    Get java.util.Collection of n untyped rows matching molecule as of transaction time t.

    Call getRawAsOf when data doesn't need to be type-casted. Datomic's raw data is returned as-is.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved in a getHistory call for an attribute and then be used to get data as of that point in time (including that transaction):

    // Insert (t 1028)
    val List(ben, liz) = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37),
    ) eids
    
    // Update (t 1031)
    Person(ben).age(43).update
    
    // History of Ben
    Person(ben).age.t.op.getHistory.sortBy(r => (r._2, r._3)) === List(
      (42, 1028, true),  // Insert:  42 asserted
      (42, 1031, false), // Update:  42 retracted
      (43, 1031, true),  //          43 asserted
    )
    
    // Get all rows of raw data as of transaction t 1031 (after update)
    Person.name.age.getRawAsOf(1028).toString === """[["Ben" 43], ["Liz" 37]]"""
    
    // Get n (1) rows of raw data as of transaction t 1031 (after update)
    Person.name.age.getRawAsOf(1031, 1).toString === """[["Ben" 43]]"""
    t

    Transaction time t

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual on getAsOf

  199. def getRawAsOf(t: Long)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of all untyped rows matching molecule as of transaction time t.

    Get java.util.Collection of all untyped rows matching molecule as of transaction time t.

    Call getRawAsOf when data doesn't need to be type-casted. Datomic's raw data is returned as-is.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved in a getHistory call for an attribute and then be used to get data as of that point in time (including that transaction):

    // Insert (t 1028)
    val List(ben, liz) = Person.name.age insert List(
      ("Ben", 42),
      ("Liz", 37),
    ) eids
    
    // Update (t 1031)
    Person(ben).age(43).update
    
    // Retract (t 1032)
    ben.retract
    
    // History of Ben
    Person(ben).age.t.op.getHistory.sortBy(r => (r._2, r._3)) === List(
      (42, 1028, true),  // Insert:  42 asserted
      (42, 1031, false), // Update:  42 retracted
      (43, 1031, true),  //          43 asserted
      (43, 1032, false)  // Retract: 43 retracted
    )
    
    // Get raw data as of transaction t 1028 (after insert)
    Person.name.age.getRawAsOf(1028).toString === """[["Ben" 42], ["Liz" 37]]"""
    
    // Get raw data as of transaction t 1031 (after update)
    Person.name.age.getRawAsOf(1031).toString === """[["Ben" 43], ["Liz" 37]]""" // Ben now 43
    
    // Get raw data as of transaction t 1032 (after retract)
    Person.name.age.getRawAsOf(1032).toString === """[["Liz" 37]]""" // Ben gone
    t

    Transaction time t

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual on getAsOf

  200. def getRawSince(date: Date, n: Int)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of n untyped rows matching molecule since date.

    Get java.util.Collection of n untyped rows matching molecule since date.

    Call getRawSince when data doesn't need to be type-casted. Datomic's raw data is returned as-is.

    Get data added/retracted since a human point in time (a java.util.Date).

    // Transact 3 times (`inst` retrieves transaction time from tx report)
    val date1 = Person.name("Ann").save.inst
    val date2 = Person.name("Ben").save.inst
    val date3 = Person.name("Cay").save.inst
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since date1
    Person.name.getRawSince(date1).toString === """[["Ben"], ["Cay"]]"""
    
    // Ben and Cay added since date1 - only n (1) rows returned
    Person.name.getRawSince(date1, 1).toString === """[["Ben"]]"""
    date

    java.util.Date

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual on getAsOf

  201. def getRawSince(date: Date)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of all untyped rows matching molecule since date.

    Get java.util.Collection of all untyped rows matching molecule since date.

    Call getRawSince when data doesn't need to be type-casted. Datomic's raw data is returned as-is.

    Get data added/retracted since a human point in time (a java.util.Date).

    // Transact 3 times (`inst` retrieves transaction time from tx report)
    val date1 = Person.name("Ann").save.inst
    val date2 = Person.name("Ben").save.inst
    val date3 = Person.name("Cay").save.inst
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since date1
    Person.name.getRawSince(date1).toString === """[["Ben"], ["Cay"]]"""
    
    // Cay added since date2
    Person.name.getRawSince(date2).toString === """[["Cay"]]"""
    
    // Nothing added since date3
    Person.name.getRawSince(date3).toString === """[]"""
    date

    java.util.Date

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual on getAsOf

  202. def getRawSince(tx: TxReport, n: Int)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of n untyped rows matching molecule since tx.

    Get java.util.Collection of n untyped rows matching molecule since tx.

    Call getRawSince when data doesn't need to be type-casted. Datomic's raw data is returned as-is.

    Datomic's internal since method can take a transaction entity id as argument to retrieve a database value since that transaction (excluding).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Get tx reports for 3 transactions
    val tx1 = Person.name("Ann").save
    val tx2 = Person.name("Ben").save
    val tx3 = Person.name("Cay").save
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since tx1
    Person.name.getRawSince(tx1).toString === """[["Ben"], ["Cay"]]"""
    
    // Ben and Cay added since tx1 - only n (1) rows returned
    Person.name.getRawSince(tx1, 1).toString === """[["Ben"]]"""
    tx

    TxReport (returned from all molecule transaction operations)

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual on getAsOf

  203. def getRawSince(tx: TxReport)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of all untyped rows matching molecule since tx.

    Get java.util.Collection of all untyped rows matching molecule since tx.

    Call getRawSince when data doesn't need to be type-casted. Datomic's raw data is returned as-is.

    Datomic's internal since method can take a transaction entity id as argument to retrieve a database value since that transaction (excluding).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Get tx reports for 3 transactions
    val tx1 = Person.name("Ann").save
    val tx2 = Person.name("Ben").save
    val tx3 = Person.name("Cay").save
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since tx1
    Person.name.getRawSince(tx1).toString === """[["Ben"], ["Cay"]]"""
    
    // Cay added since tx2
    Person.name.getRawSince(tx2).toString === """[["Cay"]]"""
    
    // Nothing added since tx3
    Person.name.getRawSince(tx3).toString === """[]"""
    tx

    TxReport (returned from all molecule transaction operations)

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual on getAsOf

  204. def getRawSince(t: Long, n: Int)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of n untyped rows matching molecule since transaction time t.

    Get java.util.Collection of n untyped rows matching molecule since transaction time t.

    Call getRawSince when data doesn't need to be type-casted. Datomic's raw data is returned as-is.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved calling t on the tx report returned from transactional operations and then be used to get data since that point in time (excluding that transaction):

    // 3 transaction times `t`
    val t1 = Person.name("Ann").save.t
    val t2 = Person.name("Ben").save.t
    val t3 = Person.name("Cay").save.t
    
    // Current values as Iterable
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since transaction time t1
    Person.name.getRawSince(t1).toString === """[["Ben"], ["Cay"]]"""
    
    // Ben and Cay added since transaction time t1 - only n (1) rows returned
    Person.name.getRawSince(t1).toString === """[["Ben"]]"""
    t

    Transaction time t

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual on getAsOf

  205. def getRawSince(t: Long)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of all untyped rows matching molecule since transaction time t.

    Get java.util.Collection of all untyped rows matching molecule since transaction time t.

    Call getRawSince when data doesn't need to be type-casted. Datomic's raw data is returned as-is.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved calling t on the tx report returned from transactional operations and then be used to get data since that point in time (excluding that transaction):

    // 3 transaction times `t`
    val t1 = Person.name("Ann").save.t
    val t2 = Person.name("Ben").save.t
    val t3 = Person.name("Cay").save.t
    
    // Current values as Iterable
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since transaction time t1
    Person.name.getRawSince(t1).toString === """[["Ben"], ["Cay"]]"""
    
    // Cay added since transaction time t2
    Person.name.getRawSince(t2).toString === """[["Cay"]]"""
    
    // Nothing added since transaction time t3
    Person.name.getRawSince(t3).toString === """[]"""
    t

    Transaction time t

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual on getAsOf

  206. def getRawWith(txData: List[_], n: Int)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of n untyped rows matching molecule with applied raw transaction data.

    Get java.util.Collection of n untyped rows matching molecule with applied raw transaction data.

    Apply raw transaction data to in-memory "branch" of db without affecting db to see how it would then look:

    // Live size of Person db
    Person.name.get.size === 150
    
    // Read some transaction data from file
    val data_rdr2 = new FileReader("examples/resources/seattle/seattle-data1a.dtm")
    val newDataTx = Util.readAll(data_rdr2).get(0).asInstanceOf[java.util.List[Object]]
    
    // Imagine future db - 100 persons would be added, apparently
    Person.name.getRawWith(newDataTx).size === 250
    
    // Imagine future db - Let's just take 10
    Person.name.getRawWith(newDataTx, 10).size === 10
    txData

    Raw transaction data as java.util.List[Object]

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual

  207. def getRawWith(txData: List[_])(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of all untyped rows matching molecule with applied raw transaction data.

    Get java.util.Collection of all untyped rows matching molecule with applied raw transaction data.

    Apply raw transaction data to in-memory "branch" of db without affecting db to see how it would then look:

    // Live size of Person db
    Person.name.get.size === 150
    
    // Read some transaction data from file
    val data_rdr2 = new FileReader("examples/resources/seattle/seattle-data1a.dtm")
    val newDataTx = Util.readAll(data_rdr2).get(0).asInstanceOf[java.util.List[Object]]
    
    // Imagine future db - 100 persons would be added, apparently
    Person.name.getRawWith(newDataTx).size === 250
    txData

    Raw transaction data as java.util.List[Object]

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual

  208. def getRawWith(n: Int, txMolecules: Seq[Seq[Statement]]*)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of n untyped rows matching molecule with applied molecule transaction data.

    Get java.util.Collection of n untyped rows matching molecule with applied molecule transaction data.

    Apply one or more molecule transactions to in-memory "branch" of db without affecting db to see how it would then look:

    // Current state
    val List(ben, liz) = Person.name.likes.insert(
      ("Ben", "pasta"),
      ("Liz", "pizza")
    ).eids
    
    // Test multiple transactions
    Person.name.likes.getRawWith(
      Person(ben).likes("sushi").getUpdateTx,
      Person(liz).likes("cake").getUpdateTx
    ).toString === """[["Ben" "sushi"], ["Liz" "cake"]]"""
    
    // Same as above, but only n (1) rows returned:
    Person.name.likes.getRawWith(
      1
      Person(ben).likes("sushi").getUpdateTx,
      Person(liz).likes("cake").getUpdateTx
    ).toString === """[["Ben" "sushi"]]"""

    Multiple transactions can be applied to test more complex what-if scenarios!

    n

    Int Number of rows returned

    txMolecules

    Transaction statements from applied Molecules with test data

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    Note

    Note how the n parameter has to come before the txMolecules vararg.

    See also

    Manual

  209. def getRawWith(txMolecules: Seq[Seq[Statement]]*)(implicit conn: Conn): Collection[List[AnyRef]]

    Get java.util.Collection of all untyped rows matching molecule with applied molecule transaction data.

    Get java.util.Collection of all untyped rows matching molecule with applied molecule transaction data.

    Apply one or more molecule transactions to in-memory "branch" of db without affecting db to see how it would then look:

    // Current state
    val ben = Person.name("Ben").likes("pasta").save.eid
    
    // Base data
    Person.name.likes.getRawWith(
      Person(ben).likes("sushi").getUpdateTx
    ).toString ==== """[["Ben" "sushi"]]"""
    
    // Current state is still the same
    Person.name.likes.get === List(("Ben", "pasta"))

    Multiple transactions can be applied to test more complex what-if scenarios!

    txMolecules

    Transaction statements from applied Molecules with test data

    conn

    Implicit Conn value in scope

    returns

    java.util.Collection[java.util.List[AnyRef]]

    Definition Classes
    GetRaw
    See also

    Manual

  210. def getSaveTx(implicit conn: Conn): Seq[Seq[Statement]]

    Get transaction statements of a call to save on a molecule (without affecting the db).

    Get transaction statements of a call to save on a molecule (without affecting the db).

    conn

    Implicit Conn value in scope

    returns

    Transaction statements

    Definition Classes
    Molecule
  211. def getSince(date: Date, n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of n rows as tuples matching molecule since date.

    Get List of n rows as tuples matching molecule since date.

    Get data added/retracted since a human point in time (a java.util.Date).

    // Transact 3 times (`inst` retrieves transaction time/Date from tx report)
    val date1 = Person.name("Ann").save.inst
    val date2 = Person.name("Ben").save.inst
    val date3 = Person.name("Cay").save.inst
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since date1
    Person.name.getSince(date1) === List("Ben", "Cay")
    
    // Ben and Cay added since date1 - only n (1) rows returned
    Person.name.getSince(date1, 1) === List("Ben")
    date

    java.util.Date

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual on since

  212. def getSince(date: Date)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of all rows as tuples matching molecule since date.

    Get List of all rows as tuples matching molecule since date.

    Get data added/retracted since a human point in time (a java.util.Date).

    // Transact 3 times (`inst` retrieves transaction time/Date from tx report)
    val date1 = Person.name("Ann").save.inst
    val date2 = Person.name("Ben").save.inst
    val date3 = Person.name("Cay").save.inst
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since date1
    Person.name.getSince(date1) === List("Ben", "Cay")
    
    // Cay added since date2
    Person.name.getSince(date2) === List("Cay")
    
    // Nothing added since date3
    Person.name.getSince(date3) === Nil
    date

    java.util.Date

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual on since

  213. def getSince(tx: TxReport, n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of n rows as tuples matching molecule since tx.

    Get List of n rows as tuples matching molecule since tx.

    Datomic's internal since can take a transaction entity id as argument to retrieve a database value since that transaction (excluding the transaction itself).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Get tx reports for 3 transactions
    val tx1 = Person.name("Ann").save
    val tx2 = Person.name("Ben").save
    val tx3 = Person.name("Cay").save
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since tx1
    Person.name.getSince(tx1) === List("Ben", "Cay")
    
    // Ben and Cay added since tx1 - only n (1) rows returned
    Person.name.getSince(tx1, 1) === List("Ben")
    tx

    TxReport

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual on since

  214. def getSince(tx: TxReport)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of all rows as tuples matching molecule since tx.

    Get List of all rows as tuples matching molecule since tx.

    Datomic's internal since can take a transaction entity id as argument to retrieve a database value since that transaction (excluding the transaction itself).

    Instead of supplying the transaction entity id, in Molecule we supply a TxReport that contains the transaction entity id (which is used as argument to Datomic internally). This is more convenient when using Molecule since we get a TxReport from transaction operations like get, update, retract etc.

    // Get tx reports for 3 transactions
    val tx1 = Person.name("Ann").save
    val tx2 = Person.name("Ben").save
    val tx3 = Person.name("Cay").save
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since tx1
    Person.name.getSince(tx1) === List("Ben", "Cay")
    
    // Cay added since tx2
    Person.name.getSince(tx2) === List("Cay")
    
    // Nothing added since tx3
    Person.name.getSince(tx3) === Nil
    tx

    TxReport

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual on since

  215. def getSince(t: Long, n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of n rows as tuples matching molecule since transaction time t.

    Get List of n rows as tuples matching molecule since transaction time t.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved by calling t on the tx report returned from transactional operations and then be used to get data since that point in time (excluding that transaction):

    // 3 transaction times `t`
    val t1 = Person.name("Ann").save.t
    val t2 = Person.name("Ben").save.t
    val t3 = Person.name("Cay").save.t
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since transaction time t 1028
    Person.name.getSince(t1) === List("Ben", "Cay")
    
    // Ben and Cay added since transaction time t 1028 - only n (1) rows returned
    Person.name.getSince(t1, 1) === List("Ben")
    t

    Transaction time t

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual on since

  216. def getSince(t: Long)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of all rows as tuples matching molecule since transaction time t.

    Get List of all rows as tuples matching molecule since transaction time t.

    Transaction time t is an auto-incremented transaction number assigned internally by Datomic.

    t can for instance be retrieved by calling t on the tx report returned from transactional operations and then be used to get data since that point in time (excluding that transaction):

    // 3 transaction times `t`
    val t1 = Person.name("Ann").save.t
    val t2 = Person.name("Ben").save.t
    val t3 = Person.name("Cay").save.t
    
    // Current values
    Person.name.get === List("Ann", "Ben", "Cay")
    
    // Ben and Cay added since transaction time t 1028
    Person.name.getSince(t1) === List("Ben", "Cay")
    
    // Cay added since transaction time t 1030
    Person.name.getSince(t2) === List("Cay")
    
    // Nothing added since transaction time t 1032
    Person.name.getSince(t3) === Nil
    t

    Transaction time t

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual on since

  217. def getUpdateTx(implicit conn: Conn): Seq[Seq[Statement]]

    Get transaction statements of a call to update on a molecule (without affecting the db).

    Get transaction statements of a call to update on a molecule (without affecting the db).

    conn

    Implicit Conn value in scope

    Definition Classes
    Molecule
  218. def getWith(txData: List[_], n: Int)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of n rows as tuples matching molecule with applied raw transaction data.

    Get List of n rows as tuples matching molecule with applied raw transaction data.

    Apply raw transaction data to in-memory "branch" of db without affecting db to see how it would then look:

    // Live size of Person db
    Person.name.get.size === 150
    
    // Read some transaction data from file
    val data_rdr2 = new FileReader("examples/resources/seattle/seattle-data1a.dtm")
    val newDataTx = Util.readAll(data_rdr2).get(0).asInstanceOf[java.util.List[Object]]
    
    // Imagine future db - 100 persons would be added, apparently
    Person.name.getWith(newDataTx).size === 250
    
    // Imagine future db - Let's just take 10
    Person.name.getWith(newDataTx, 10).size === 10
    txData

    Raw transaction data as java.util.List[Object]

    n

    Int Number of rows returned

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual

  219. def getWith(txData: List[_])(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of all rows as tuples matching molecule with applied raw transaction data.

    Get List of all rows as tuples matching molecule with applied raw transaction data.

    Apply raw transaction data to in-memory "branch" of db without affecting db to see how it would then look:

    // Live size of Person db
    Person.name.get.size === 150
    
    // Read some transaction data from file
    val data_rdr2 = new FileReader("examples/resources/seattle/seattle-data1a.dtm")
    val newDataTx = Util.readAll(data_rdr2).get(0).asInstanceOf[java.util.List[Object]]
    
    // Imagine future db - 100 persons would be added, apparently
    Person.name.getWith(newDataTx).size === 250
    txData

    Raw transaction data as java.util.List[Object]

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual

  220. def getWith(n: Int, txMolecules: Seq[Seq[Statement]]*)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of n rows as tuples matching molecule with applied molecule transaction data.

    Get List of n rows as tuples matching molecule with applied molecule transaction data.

    Apply one or more molecule transactions to in-memory "branch" of db without affecting db to see how it would then look:

    // Current state
    val List(ben, liz) = Person.name.likes.insert(
      ("Ben", "pasta"),
      ("Liz", "pizza")
    ).eids
    
    // Test multiple transactions
    Person.name.likes.getWith(
      Person(ben).likes("sushi").getUpdateTx,
      Person(liz).likes("cake").getUpdateTx
    ) === List(
      ("Ben", "sushi")
      ("Liz", "cake")
    )
    
    // Same as above, but only n (1) rows returned:
    Person.name.likes.getWith(
      1
      Person(ben).likes("sushi").getUpdateTx,
      Person(liz).likes("cake").getUpdateTx
    ) === List(
      ("Ben", "sushi")
    )
    n

    Int Number of rows returned

    txMolecules

    Transaction statements from applied Molecules with test data

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    Note

    Note how the n parameter has to come before the txMolecules vararg.

    See also

    Manual

  221. def getWith(txMolecules: Seq[Seq[Statement]]*)(implicit conn: Conn, ev: ClassTag[(A, B, C, D, E, F, G, H, I)]): List[(A, B, C, D, E, F, G, H, I)]

    Get List of all rows as tuples matching molecule with applied molecule transaction data.

    Get List of all rows as tuples matching molecule with applied molecule transaction data.

    Apply one or more molecule transactions to in-memory "branch" of db without affecting db to see how it would then look:

    // Current state
    val ben = Person.name("Ben").likes("pasta").save.eid
    
    // Base data
    Person.name.likes.getWith(
      // apply imaginary transaction data
      Person(ben).likes("sushi").getUpdateTx
    ) === List(
      // Effect: Ben would like sushi if tx was applied
      ("Ben", "sushi")
    )
    
    // Current state is still the same
    Person.name.likes.get === List(("Ben", "pasta"))

    Multiple transactions can be applied to test more complex what-if scenarios!

    txMolecules

    Transaction statements from applied Molecules with test data

    conn

    Implicit Conn value in scope

    returns

    List[Tpl] where Tpl is a tuple of data matching molecule

    Definition Classes
    GetList
    See also

    Manual

  222. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  223. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  224. def jsonAggr(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  225. def jsonAggrDate(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  226. def jsonAggrLazySeq(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  227. def jsonAggrLazySeqDate(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  228. def jsonAggrLazySeqQuoted(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  229. def jsonAggrLazySeqToString(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  230. def jsonAggrListLazySeq(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  231. def jsonAggrListLazySeqDate(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  232. def jsonAggrListLazySeqQuoted(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  233. def jsonAggrListLazySeqToString(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  234. def jsonAggrListVector(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  235. def jsonAggrListVectorDate(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  236. def jsonAggrListVectorQuoted(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  237. def jsonAggrListVectorToString(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  238. def jsonAggrQuoted(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  239. def jsonAggrToString(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  240. def jsonAggrVector(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  241. def jsonAggrVectorDate(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  242. def jsonAggrVectorQuoted(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  243. def jsonAggrVectorToString(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  244. def jsonMany(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  245. def jsonManyDate(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  246. def jsonManyQuoted(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  247. def jsonManyToString(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  248. def jsonMap(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  249. def jsonMapDate(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  250. def jsonMapQuoted(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  251. def jsonOne(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  252. def jsonOneAny(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  253. def jsonOneDate(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  254. def jsonOneQuoted(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  255. def jsonOneToString(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  256. def jsonOptMany(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  257. def jsonOptManyDate(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  258. def jsonOptManyEnum(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  259. def jsonOptManyQuoted(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  260. def jsonOptManyToString(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  261. def jsonOptMap(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  262. def jsonOptMapDate(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  263. def jsonOptMapQuoted(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  264. def jsonOptOne(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  265. def jsonOptOneDate(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  266. def jsonOptOneEnum(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  267. def jsonOptOneQuoted(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  268. def jsonOptOneToString(sb: StringBuilder, field: String, row: List[_], i: Int): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  269. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  270. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  271. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  272. final def o(opt: Option[Any]): String
    Attributes
    protected
    Definition Classes
    Helpers
  273. def pair(sb: StringBuilder, field: String, value: Any): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  274. def quote(sb: StringBuilder, s: String): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  275. def quotedPair(sb: StringBuilder, field: String, value: String): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  276. def row2json(sb: StringBuilder, row: List[AnyRef]): StringBuilder
    Attributes
    protected
    Definition Classes
    JsonBuilder
  277. def save(implicit conn: Conn): TxReport

    Save data applied to molecule attributes.

    Save data applied to molecule attributes.

    val txReport = Person.name("Ben").age(42).save
    
    // Data has been saved in db
    Person.name.age.get === List(("Ben", 42))

    A TxReport is returned with info about the result of the save transaction.

    The save operation is synchronous and can be wrapped in a Future if asynchronicity is required.

    conn

    Implicit Conn value in scope

    returns

    TxReport

    Definition Classes
    Molecule
  278. final lazy val sdf: SimpleDateFormat
    Attributes
    protected
    Definition Classes
    Helpers
  279. final def seq[T](values: Seq[T]): String
    Attributes
    protected
    Definition Classes
    Helpers
  280. final def synchronized[T0](arg0: ⇒ T0): T0
    Definition Classes
    AnyRef
  281. final def time(n: Int, prev: Int = 0): Unit
    Attributes
    protected
    Definition Classes
    Helpers
  282. def toString(): String
    Definition Classes
    AnyRef → Any
  283. final def tupleToSeq(arg: Any): Seq[Any]
    Attributes
    protected
    Definition Classes
    Helpers
  284. def update(implicit conn: Conn): TxReport

    Update entity with data applied to molecule attributes.

    Update entity with data applied to molecule attributes.

    // Current data
    val ben = Person.name("Ben").age(42).save.eid
    
    // Update entity of of Ben with new age value
    Person(ben).age(43).update
    
    // Ben is now 43
    Person.name.age.get === List(("ben", 43))

    A TxReport is returned with info about the result of the update transaction.

    The update operation is synchronous and can be wrapped in a Future if asynchronicity is required.

    conn

    Implicit Conn value in scope

    returns

    TxReport

    Definition Classes
    Molecule
  285. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  286. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  287. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @native() @throws( ... )
  288. val xx: Array[Int]
    Definition Classes
    GetList
  289. object debugInsert extends debugInsert with checkInsertModel

    See debugInsert

  290. object getInsertTx extends getInsertTx with checkInsertModel

    See getInsertTx

  291. object insert extends insert with checkInsertModel

    See insert

  292. object mkDate
    Attributes
    protected
    Definition Classes
    Helpers

Inherited from Molecule[(A, B, C, D, E, F, G, H, I)]

Inherited from ShowDebug[(A, B, C, D, E, F, G, H, I)]

Inherited from GetJson

Inherited from GetRaw

Inherited from GetList[(A, B, C, D, E, F, G, H, I)]

Inherited from GetIterable[(A, B, C, D, E, F, G, H, I)]

Inherited from GetArray[(A, B, C, D, E, F, G, H, I)]

Inherited from JsonBuilder

Inherited from CastHelpers[(A, B, C, D, E, F, G, H, I)]

Inherited from Helpers

Inherited from MoleculeBase

Inherited from AnyRef

Inherited from Any

get

asof

getArrayAsOf

getIterableAsOf

getJsonAsOf

getRawAsOf

getSince

getArraySince

getIterableSince

getJsonSince

getRawSince

getWith

getArrayWith

getIterableWith

getJsonWith

getRawWith

getHistory

(only implemented to return default List of tuples)

save

insert

update

tx

Debug get

Molecule getter debugging methods.

Debug action

Molecule action debugging methods (no effect on live db).

Internal (but public) model/query representations

Ungrouped