Releases: objectbox/objectbox-java
V2.9.1
This is the first release available on the Central repository (Sonatype OSSRH). Make sure to adjust your build.gradle
files accordingly:
repositories {
mavenCentral()
}
Changes:
- Javadoc for
find(offset, limit)
ofQuery
is more concrete on how offset and limit work. - Javadoc for between conditions explicitly mentions it is inclusive of the two given values.
- Sync: Instead of the same name and a Maven classifier, Sync artifacts now use a different name. E.g.
objectbox-android:2.9.0:sync
is replaced withobjectbox-sync-android:2.9.1
.
V2.9.0
- Query: Add
lessOrEqual
andgreaterOrEqual
conditions for long, String, double and byte[] properties. - Support Java applications on ARMv7 and AArch64 devices. #657
To use, addimplementation "io.objectbox:objectbox-linux-armv7:$objectboxVersion
orimplementation "io.objectbox:objectbox-linux-arm64:$objectboxVersion
to your dependencies. Otherwise the setup is identical with Java Desktop Apps. - Resolve rare
ClassNotFoundException: kotlin.text.Charsets
when running processor. #946 - Ensure Query setParameters works if running the x86 library on x64 devices (which could happen if ABI filters were set up incorrectly). #927
V2.8.1
- Minor improvements to Sync tooling.
See the 2.8.0 release notes for the latest changes.
V2.8.0
- Added Sync API.
- Fixed "illegal reflective access" warning in the plugin.
- The data browser notification is now silent by default, for quieter testing. #903
- Updated and improved API documentation in various places (e.g. on how
Query.findLazy()
andQuery.findLazyCached()
work withLazyList
#906). - Print full name and link to element for
@Index
and@Id
errors. #902 - Explicitly allow to remove a
DbExceptionListener
by accepting null values forBoxStore.setDbExceptionListener(listener)
.
V2.7.1
- Fix exception handling during
BoxStoreBuilder.build()
to allow retries. For example, after aFileCorruptException
you could try to open the database again using the recently addedusePreviousCommit()
option. - Add
PagesCorruptException
as a special case ofFileCorruptException
. DbExceptionListener
is called more robustly.
V2.7.0
- Several database store improvements for BoxStore and BoxStoreBuilder
- New configuration options to open the database, e.g. a new read-only mode and using the previous data snapshot (second last commit) to potentially recover data.
- Database validation. We got a GitHub report indicating that some specific devices ship with a broken file system. While this is not a general concern (file systems should not be broken), we decided to detect some typical problems and provide some options to deal with these.
- Get the size on disk
- Add an efficient check if an object exist in a Box via contains(id).
- Android improvements
- Resolve Android Studio Build Analyzer warning about a prepare tasks not specifying outputs.
- Data Browser drawables are no longer packaged in the regular Android library. #857
- Fixes for one-to-many relations, e.g. allow removing both entity classes of a one-to-many relation. #859
See also https://docs.objectbox.io/
V2.6.0
@DefaultValue("")
annotation. Annotated properties will return the specified default value (currently only""
is supported) instead of null. This is useful if a not-null property is added to an entity, but there are existing entities in the database that will return null for the new property.
Note: naming is not final, it may change to e.g.@AbsentValue("")
. #157- RxJava 3 support library
objectbox-rxjava3
. Also includes Kotlin extension functions to more easily obtain Rx types, e.g. usequery.observable()
to get anObservable
. #83 - The annotation processor is incremental by default. #620
- Fix error handling if ObjectBox can't create a Java entity (the proper exception is now thrown).
- Support setting an alias after combining conditions using and() or or(). #83
- Add documentation that string property conditions ignore case by default. Point to using case-sensitive conditions for high-performance look-ups, e.g. when using string UIDs.
- Repository Artifacts are signed once again.
Changes since 2.6.0-RC (released on 2020/04/28):
- Performance improvements with query links (aka "joins").
Note: the order of results has changed unless you explicitly specified properties to order by. Remember: you should not depend on any internal order. If you did, this is a good time to fix it. objectbox-java
no longer exposes the greenrobot-essentials and FlatBuffers dependencies to consuming projects.- Minor code improvements.
See the full changelog for more details.
V2.6.0-RC
V3.0.0-alpha2
Note: this is a preview release. Future releases may add, change or remove APIs.
- Add Kotlin infix extension functions for creating conditions using the new Query API. See the documentation for examples.
- The old Query API now also supports setting an alias after combining conditions using
and()
oror()
. #834 - Add documentation that string property conditions ignore case by default. Point to using case-sensitive conditions for high-performance look-ups, e.g. when using string UIDs.
- Java's
String[]
and Kotlin'sArray<String>
are now a supported database type. A converter is no longer necessary to store these types. Using thearrayProperty.equal("item")
condition, it is possible to query for entities where "item" is equal to one of the array items. - Support
@Unsigned
to indicate that values of an integer property (e.g.Integer
andLong
in Java) should be treated as unsigned when doing queries or creating indexes. See the Javadoc of the annotation for more details. Support marking 64-bit integer properties (e.g.This is not ready, yet.Long
in Java) with@Type(DateNano)
to indicate the database should treat these values as time with nanosecond precision. Note: to store time in millisecond precision continue to usejava.util.Date
(without annotation).- Add new library to support RxJava 3,
objectbox-rxjava3
. In addition,objectbox-kotlin
adds extension functions to more easily obtain Rx types, e.g. usequery.observable()
to get anObservable
. #839
To use this release change the version of objectbox-gradle-plugin
to 3.0.0-alpha2
. The plugin now properly adds the preview version of objectbox-java
to your dependencies.
buildscript {
dependencies {
classpath "io.objectbox:objectbox-gradle-plugin:3.0.0-alpha2"
}
}
dependencies {
// Artifacts with native code remain at 2.5.1.
implementation "io.objectbox:objectbox-android:2.5.1"
}
The objectbox-android
, objectbox-linux
, objectbox-macos
and objectbox-windows
artifacts shipping native code remain at version 2.5.1
as there have been no changes. If you explicitly include them, make sure to specify their version as 2.5.1
.
V3.0.0-alpha1
Note: this is a preview release. Future releases may add, change or remove APIs.
- A new Query API provides support for nested AND and OR conditions. See the documentation for examples and notable changes. #201
- Subscriptions now publish results in serial instead of in parallel (using a single thread vs. multiple threads per publisher). Publishing in parallel could previously lead to outdated results getting delivered after the latest results. As a side-effect transformers now run in serial instead of in parallel as well (on the same single thread per publisher). #793
- Turn on incremental annotation processing by default. #620
To use this release change the version of objectbox-gradle-plugin
to 3.0.0-alpha1
and add a dependency on objectbox-java
version 3.0.0-alpha1
.
buildscript {
dependencies {
classpath "io.objectbox:objectbox-gradle-plugin:3.0.0-alpha1"
}
}
dependencies {
implementation "io.objectbox:objectbox-java:3.0.0-alpha1"
// Artifacts with native code remain at 2.5.1.
implementation "io.objectbox:objectbox-android:2.5.1"
}
The objectbox-android
, objectbox-linux
, objectbox-macos
and objectbox-windows
artifacts shipping native code remain at version 2.5.1 as there have been no changes. However, if your project explicitly depends on them they will pull in version 2.5.1 of objectbox-java
. Make sure to add an explicit dependency on of objectbox-java
version 3.0.0-alpha1
as mentioned above.