Releases: objectbox/objectbox-java
V3.7.1
V3.7.0
- A new key/value validation option validateOnOpenKv()is available onMyObjectBox.builder()to help diagnoseFileCorruptException: Corrupt DB, min key size violatedissues. If enabled, thebuild()call will throw aFileCorruptExceptionif corruption is detected with details on which key/value is affected. #1143
- Admin: integer and floating point arrays introduced with the previous release are now nicely displayed and collapsed if long.
- Admin: the data table again displays all items of a page. #1135
- The __cxa_pure_virtualcrash should not occur anymore; if you get related exceptions, they should contain additional information to better diagnose this issue. Let us know details in #1131
- Queries: all expected results are now returned when using a less-than or less-or-equal condition for a String property with index type VALUE. Reported via objectbox-dart#318
- Queries: when combining multiple conditions with OR and adding a condition on a related entity ("link condition") the combined conditions are now properly applied. Reported via objectbox-dart#546
- Some flags classes have moved to the new configpackage:- io.objectbox.DebugFlagsis deprecated, use- io.objectbox.config.DebugFlagsinstead.
- io.objectbox.model.ValidateOnOpenModeis deprecated, use- io.objectbox.config.ValidateOnOpenModePagesinstead.
 
V3.6.0
- 
Support for integer and floating point arrays: store - short[],- char[],- int[],- long[]and
- float[]and- double[]
 (or their Kotlin counterparts, e.g. FloatArray) without a converter.A simple example is a shape entity that stores a palette of RGB colors: @Entity public class Shape { @Id public long id; // An array of RGB color values that are used by this shape. public int[] palette; } // Find all shapes that use red in their palette try (Query<Shape> query = store.boxFor(Shape.class) .query(Shape_.palette.equal(0xFF0000)) .build()) { query.findIds(); } This can also be useful to store vector embeddings produced by machine learning, e.g.: @Entity public class ImageEmbedding { @Id public long id; // Link to the actual image, e.g. on Cloud storage public String url; // The coordinates computed for this image (vector embedding) public float[] coordinates; } 
- 
Fix incorrect Cursor code getting generated when using @Convertto convert to aStringarray.
- 
The io.objectbox.syncplugin now also automatically adds a Sync-enabled JNI library on macOS and Windows (previously on Linux x64 only; still need to add manually for Linux on ARM).
We're hiring! 😎 We believe resource-efficient coding is still cool and are looking for a C / C++ developer who shares our sentiment.
V3.5.1
- Fixes writes failing with "error code -30786", which may occur in some corner cases on some devices. #1099
- Add docs to DbSchemaExceptionon how to resolve its typical causes.
We're hiring! 😎 We believe resource-efficient coding is still cool and are looking for a C / C++ developer who shares our sentiment.
V3.5.0
This release includes breaking changes to generated code. If you encounter build errors, make sure to clean and build your project (e.g. Build > Rebuild project in Android Studio).
- Add Query.copy()andQueryThreadLocalto obtain aQueryinstance to use in different threads. Learn more about re-using queries. #1071
- Add relationCountquery condition to match objects that have a certain number of related objects pointing to them. E.g.Customer_.orders.relationCount(2)will match all customers with two orders,Customer_.orders.relationCount(0)will match all customers with no associated order. This can be useful to find objects where the relation was dissolved, e.g. after the related object was removed.
- Allow using a relation target ID property with a property query. E.g. query.property(Order_.customerId)will map results to the ID of the customer of an order. #1028
- Add docs on DbFullExceptionabout why it occurs and how to handle it.
- Do not fail to transform an entity class that contains a transient relation field when using Android Gradle Plugin 7.1 or lower.
- Restore compatibility for Android projects using Gradle 6.1. The minimum supported version for Gradle is 6.1 and for the Android Gradle Plugin 3.4. This should make it easier for older projects to update to the latest version of ObjectBox.
Using Sync? This release uses a new Sync protocol which improves efficiency. Reach out via your existing contact to check if any actions are required for your setup.
V3.4.0
- Add findFirstId()andfindUniqueId()toQuerywhich just return the ID of a matching object instead of the full object.
- Experimental support for setting a maximum data size via the maxDataSizeInKByteproperty when building a Store. This is different from the existingmaxSizeInKByteproperty in that it is possible to remove data after reaching the limit and continue to use the database. See its documentation for more details.
- Fix a crash when querying a value-based index (e.g. @Index(type = IndexType.VALUE)) on Android 32-bit ARM devices. #1105
- Various small improvements to the native libraries.
Using Sync? There is no Sync version for this release, please continue using version 3.2.1.
V3.3.1
Note: V3.3.0 contains a bug preventing correct transformation of some classes, please use V3.3.1 instead.
- Gradle plugin: use new transform API with Android Plugin 7.2.0 and newer. Builds should be slightly faster as only entity and cursor classes and only incremental changes are transformed. #1078
- Gradle plugin: improve detection of applied Android plugins, improve registration of byte-code transform for non-Android Java projects, add check for minimum supported version of Gradle.
- Various small improvements to the native libraries.
Using Sync? There is no Sync version for this release, please continue using version 3.2.1.
V3.2.1
V3.2.0
- Query: throw IllegalStateExceptionwhen query is closed instead of crashing the virtual machine. #1081
- BoxStore and Query now throw IllegalStateExceptionwhen trying to subscribe but the store or query is closed already.
- Various internal improvements including minor optimizations for binary size and performance.
V3.1.3
- Windows: using a database directory path that contains unicode (UTF-8) characters does not longer create an additional, unused, directory with garbled characters.
- Query: when using a negative offset or limit display a helpful error message.
- Processor: do not crash, but error if ToOne/ToMany type arguments are not supplied (e.g. ToOneinstead ofToOne<Entity>).
- The Data Browser has been renamed to ObjectBox Admin. Deprecated AndroidObjectBrowser, useAdmininstead.AndroidObjectBrowserwill be removed in a future release.