abstract class CRUD[T, PrimaryKeyType] extends CRUDAction[T, PrimaryKeyType] with JdbcProfileComponent[DbAppConfig]
Created by chris on 9/8/16. This is an abstract actor that can be used to implement any sort of actor that accesses a Postgres database. It creates read, update, upsert, and delete methods for your actor to call. You are responsible for the create function. You also need to specify the table and the database you are connecting to.
- Alphabetic
- By Inheritance
- CRUD
- CRUDAction
- JdbcProfileComponent
- BitcoinSLogger
- AnyRef
- Any
- Hide All
- Show All
- Public
- Protected
Instance Constructors
-  new CRUD()(implicit ec: ExecutionContext, appConfig: DbAppConfig)
Abstract Value Members
-  abstract def createAll(ts: Vector[T]): Future[Vector[T]]
-   abstract  def createAllAction(ts: Vector[T]): slick.jdbc.JdbcProfile.JdbcAPI.DBIOAction[Vector[T], slick.jdbc.JdbcProfile.JdbcAPI.NoStream, Write]- Definition Classes
- CRUDAction
 
-   abstract  def findAll(ts: Vector[T]): slick.jdbc.JdbcProfile.JdbcAPI.Query[slick.jdbc.JdbcProfile.JdbcAPI.Table[T], T, Seq]- Attributes
- protected
- Definition Classes
- CRUDAction
 
-   abstract  def findByPrimaryKeys(ids: Vector[PrimaryKeyType]): slick.jdbc.JdbcProfile.JdbcAPI.Query[slick.jdbc.JdbcProfile.JdbcAPI.Table[T], T, Seq]Finds the rows that correlate to the given primary keys Finds the rows that correlate to the given primary keys - Attributes
- protected
- Definition Classes
- CRUDAction
 
-   abstract  val table: slick.jdbc.JdbcProfile.JdbcAPI.TableQuery[_ <: slick.jdbc.JdbcProfile.JdbcAPI.Table[T]]The table inside our database we are inserting into The table inside our database we are inserting into - Definition Classes
- CRUDAction
 
Concrete Value Members
-   final  def !=(arg0: Any): Boolean- Definition Classes
- AnyRef → Any
 
-   final  def ##: Int- Definition Classes
- AnyRef → Any
 
-   final  def ==(arg0: Any): Boolean- Definition Classes
- AnyRef → Any
 
-   implicit  val appConfig: DbAppConfig- Definition Classes
- CRUD → CRUDAction → JdbcProfileComponent
 
-   final  def asInstanceOf[T0]: T0- Definition Classes
- Any
 
-    def clone(): AnyRef- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.CloneNotSupportedException]) @native()
 
-    def count(): Future[Int]Returns number of rows in the table 
-    def countAction: slick.jdbc.JdbcProfile.JdbcAPI.DBIOAction[Int, slick.jdbc.JdbcProfile.JdbcAPI.NoStream, Read]- Definition Classes
- CRUDAction
 
-    def create(t: T): Future[T]create a record in the database create a record in the database - t
- \- the record to be inserted 
- returns
- the inserted record 
 
-    def createAction(t: T): slick.jdbc.JdbcProfile.JdbcAPI.DBIOAction[T, slick.jdbc.JdbcProfile.JdbcAPI.NoStream, Write]- Definition Classes
- CRUDAction
 
-    lazy val database: JdbcDatabaseDefThe database we are connecting to The database we are connecting to - Definition Classes
- JdbcProfileComponent
 
-    lazy val dbConfig: DatabaseConfig[JdbcProfile]The configuration details for connecting/using the database for our projects that require database connections The configuration details for connecting/using the database for our projects that require database connections - Definition Classes
- JdbcProfileComponent
 
-    def delete(t: T): Future[Int]delete the corresponding record in the database delete the corresponding record in the database - t
- \- the record to be deleted 
- returns
- int - the number of rows affected by the deletion 
 
-    def deleteAction(t: T): slick.jdbc.JdbcProfile.JdbcAPI.DBIOAction[Int, slick.jdbc.JdbcProfile.JdbcAPI.NoStream, Write]- Definition Classes
- CRUDAction
 
-    def deleteAll(): Future[Int]delete all records from the table 
-  def deleteAll(ts: Vector[T]): Future[Int]
-    def deleteAllAction(): slick.jdbc.JdbcProfile.JdbcAPI.DBIOAction[Int, slick.jdbc.JdbcProfile.JdbcAPI.NoStream, Write with Transactional]WARNING: Deletes all rows in table, use with care WARNING: Deletes all rows in table, use with care - Definition Classes
- CRUDAction
 
-    def deleteAllAction(ts: Vector[T]): slick.jdbc.JdbcProfile.JdbcAPI.DBIOAction[Int, slick.jdbc.JdbcProfile.JdbcAPI.NoStream, Write]- Definition Classes
- CRUDAction
 
-   implicit  val ec: ExecutionContext- Definition Classes
- CRUD → CRUDAction
 
-   final  def eq(arg0: AnyRef): Boolean- Definition Classes
- AnyRef
 
-    def equals(arg0: AnyRef): Boolean- Definition Classes
- AnyRef → Any
 
-    def finalize(): Unit- Attributes
- protected[lang]
- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.Throwable])
 
-    def find(t: T): slick.jdbc.JdbcProfile.JdbcAPI.Query[slick.jdbc.JdbcProfile.JdbcAPI.Table[T], T, Seq]- Attributes
- protected
- Definition Classes
- CRUDAction
 
-    def findAll(): Future[Vector[T]]Finds all elements in the table 
-    def findAllAction(): slick.jdbc.JdbcProfile.JdbcAPI.DBIOAction[Vector[T], slick.jdbc.JdbcProfile.JdbcAPI.NoStream, Read]- Definition Classes
- CRUDAction
 
-    def findByPrimaryKey(id: PrimaryKeyType): slick.jdbc.JdbcProfile.JdbcAPI.Query[slick.jdbc.JdbcProfile.JdbcAPI.Table[T], T, Seq]return all rows that have a certain primary key return all rows that have a certain primary key - id
- primary key of the row to return 
- returns
- Query object corresponding to the selected rows 
 - Attributes
- protected
- Definition Classes
- CRUDAction
 
-    def findByPrimaryKeyAction(id: PrimaryKeyType): slick.jdbc.JdbcProfile.JdbcAPI.DBIOAction[Option[T], slick.jdbc.JdbcProfile.JdbcAPI.NoStream, Read]- Definition Classes
- CRUDAction
 
-    def findByPrimaryKeysAction(ids: Vector[PrimaryKeyType]): slick.jdbc.JdbcProfile.JdbcAPI.DBIOAction[Vector[T], slick.jdbc.JdbcProfile.JdbcAPI.NoStream, Read]- Definition Classes
- CRUDAction
 
-   final  def getClass(): Class[_ <: AnyRef]- Definition Classes
- AnyRef → Any
- Annotations
- @native()
 
-    def hashCode(): Int- Definition Classes
- AnyRef → Any
- Annotations
- @native()
 
-   final  def isInstanceOf[T0]: Boolean- Definition Classes
- Any
 
-    def logger: Logger- Definition Classes
- BitcoinSLogger
 
-   final  def ne(arg0: AnyRef): Boolean- Definition Classes
- AnyRef
 
-   final  def notify(): Unit- Definition Classes
- AnyRef
- Annotations
- @native()
 
-   final  def notifyAll(): Unit- Definition Classes
- AnyRef
- Annotations
- @native()
 
-    lazy val numThreads: Int- Definition Classes
- JdbcProfileComponent
 
-   final  lazy val profile: JdbcProfile- Definition Classes
- JdbcProfileComponent
 
-    def read(id: PrimaryKeyType): Future[Option[T]]read a record from the database read a record from the database - id
- \- the id of the record to be read 
- returns
- Option[T] - the record if found, else none 
 
-    def safeDatabase: SafeDatabaseBinding to the actual database itself, this is what is used to run querys 
-  val schemaName: Option[String]
-    def startHikariLogger(interval: Duration): HikariLoggingStarts the background logger for hikari Starts the background logger for hikari - interval
- \- how often hikari logs database connection pool information 
 - Attributes
- protected
- Definition Classes
- JdbcProfileComponent
 
-    def stopHikariLogger(): Unit- Attributes
- protected
- Definition Classes
- JdbcProfileComponent
 
-   final  def synchronized[T0](arg0: => T0): T0- Definition Classes
- AnyRef
 
-   implicit  def tableQuerySafeSubtypeCast[SpecificT <: AbstractTable[_], SomeT <: SpecificT](tableQuery: slick.jdbc.JdbcProfile.JdbcAPI.TableQuery[SomeT]): slick.jdbc.JdbcProfile.JdbcAPI.TableQuery[SpecificT]We need to cast from TableQuery's of internal types (e.g. We need to cast from TableQuery's of internal types (e.g. AddressDAO#AddressTable) to external versions of them (e.g. AddressDAO().table). You'll notice that although the latter is a subtype of the first, this requires a cast since TableQuery is not covariant in its type parameter. However, since Query is covariant in its first type parameter, I believe the cast from TableQuery[T1] to TableQuery[T2] will always be safe so long as T1 is a subtype of T2 AND T1#TableElementType is equal to T2#TableElementType. The above conditions are always the case when this is called within DAOs as it is only ever used for things of the form TableQuery[XDAO().table] -> TableQuery[XDAO#XTable]. - Attributes
- protected
 
-    def toString(): String- Definition Classes
- AnyRef → Any
 
-    def update(t: T): Future[T]Update the corresponding record in the database 
-    def updateAction(t: T): slick.jdbc.JdbcProfile.JdbcAPI.DBIOAction[T, slick.jdbc.JdbcProfile.JdbcAPI.NoStream, Write]- Definition Classes
- CRUDAction
 
-  def updateAll(ts: Vector[T]): Future[Vector[T]]
-    def updateAllAction(ts: Vector[T]): slick.jdbc.JdbcProfile.JdbcAPI.DBIOAction[Vector[T], slick.jdbc.JdbcProfile.JdbcAPI.NoStream, Write]Updates all of the given ts. Updates all of the given ts. Returns all ts that actually existed in the database and got updated This method discards things that did not exist in the database, thus could not be updated - Definition Classes
- CRUDAction
 
-    def upsert(t: T): Future[T]insert the record if it does not exist, update it if it does insert the record if it does not exist, update it if it does - t
- \- the record to inserted / updated 
- returns
- t - the record that has been inserted / updated 
 
-    def upsertAction(t: T): slick.jdbc.JdbcProfile.JdbcAPI.DBIOAction[T, slick.jdbc.JdbcProfile.JdbcAPI.NoStream, Write with Read]- Definition Classes
- CRUDAction
 
-    def upsertAll(ts: Vector[T]): Future[Vector[T]]Upserts all of the given ts in the database, then returns the upserted values 
-    def upsertAllAction(ts: Vector[T]): slick.jdbc.JdbcProfile.JdbcAPI.DBIOAction[Vector[T], slick.jdbc.JdbcProfile.JdbcAPI.NoStream, Write with Read]Upsert all of the given ts. Upsert all of the given ts. Returns all ts that were inserted or updated - Definition Classes
- CRUDAction
- See also
- https://scala-slick.org/doc/3.3.3/queries.html#upserting 
 
-   final  def wait(): Unit- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
 
-   final  def wait(arg0: Long, arg1: Int): Unit- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException])
 
-   final  def wait(arg0: Long): Unit- Definition Classes
- AnyRef
- Annotations
- @throws(classOf[java.lang.InterruptedException]) @native()