Skip to content

Latest commit

 

History

History
105 lines (77 loc) · 3.15 KB

README.md

File metadata and controls

105 lines (77 loc) · 3.15 KB

Batch Light

Jitpack

Batch Light is a library for batch inserting to SQLite on Android.

A demo project can be found on Google Play, and as an Instant App.

Demo Project on Google Play

Download

For simplicity the project is hosted on JitPack. The project can be added to an Android Gradle project by doing the following:

Step 1. Add the JitPack repository to your root build.gradle at the end of repositories:

allprojects {
	repositories {
		...
	    maven { url 'https://jitpack.io' }
	}
}

Step 2. Add the dependency

dependencies {
	implementation 'com.github.yelloco:Batchlight:v1.0'
}

Usage

Batch Lite has 4 main steps to use.

  1. Create a configuration object. Currently SQLite is the only binder available with the batcher. The SQLiteBinderConfig has to default types available, Insert (INSERT INTO) and Replace (REPLACE INTO). When getting an instance of the SQLiteBinderConfig there are three params. A reference to the SQLite Database being written to, the name of the table being written to and the number of columns that will be written to.
val binderConfig = SQLiteBinderConfig.getInsertConfig(
    db = writableDatabase,
    tableName = batchTableName,
    columnCount = 3
)
  1. Create a new batcher using the config from step 1.
val batcher = BatchStatement<MediumSizeObject>(binderConfig)
  1. call the execute function on the batcher, passing in the list to be inserted and a closure that tells it how to bind the items in the list. The config will generate a statement that looks like:
data class InsertItem(val id: Int, val text: String)

Table structure:

TABLE_NAME
-----------
id | text | 

The generated SQLite for a list of 3 of the items above would be:

INSERT INTO TABLE_NAME VALUES (?, ?), (?, ?), (?, ?)

To bind the list, the closure below should be used. The binder will use the closure for each item to bind to the generated statement.

batcher.execute(list) { listItem ->
    bindLong(listItem.id.toLong())
    bindString(listItem.text)
}
  1. The Batch Lite does not handle transactions. It is left up to the end user to wrap the batch insert into a transaction. If the list that is being batched is over 10,000 items it is recommended to chunk the list and batch it in separate transactions to avoid blocking other inserts happening in the application.

An example usage can be found in the sample project.

Check out the Kdoc for full documentation.

Contributing

Please read Contributing.md for details on the process for submitting pull requests.

License

This project is licensed under the MIT License - see the License.txt file for details.

Questions

Any questions comments or concerns can be directed to [email protected].