Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/objectbox/objectbox-java
Android Database - first and fast, lightweight on-device vector database
https://github.com/objectbox/objectbox-java
android database edge embedded java kotlin mobile nosql sqlite sustainable sync vector
Last synced: 5 days ago
JSON representation
Android Database - first and fast, lightweight on-device vector database
- Host: GitHub
- URL: https://github.com/objectbox/objectbox-java
- Owner: objectbox
- License: apache-2.0
- Created: 2017-01-24T10:29:48.000Z (almost 8 years ago)
- Default Branch: main
- Last Pushed: 2024-10-21T12:59:57.000Z (3 months ago)
- Last Synced: 2024-12-31T09:05:05.876Z (12 days ago)
- Topics: android, database, edge, embedded, java, kotlin, mobile, nosql, sqlite, sustainable, sync, vector
- Language: Java
- Homepage: https://objectbox.io
- Size: 2.67 MB
- Stars: 4,433
- Watchers: 104
- Forks: 305
- Open Issues: 155
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-starred - objectbox/objectbox-java - Java and Android Database - fast and lightweight without any ORM (android)
README
Getting Started •
Documentation •
Example Apps •
Issues# ObjectBox - Fast and Efficient Java Database (Android, JVM) with Vector Search
ObjectBox Java is a lightweight yet powerful on-device database & vector database designed specifically for **Java and Kotlin** applications.
Store and manage data effortlessly in your Android or JVM Linux, macOS or Windows app with ObjectBox.
Easily manage vector data alongside your objects and perform superfast on-device vector search to empower your apps with RAG AI, generative AI, and similarity search.
Enjoy exceptional speed, battery-friendly resource usage, and environmentally-friendly development. 💚## Demo code
```java
// Java
Playlist playlist = new Playlist("My Favorites");
playlist.songs.add(new Song("Lalala"));
playlist.songs.add(new Song("Lololo"));
box.put(playlist);
```➡️ [More details in the docs](https://docs.objectbox.io/)
```kotlin
// Kotlin
val playlist = Playlist("My Favorites")
playlist.songs.add(Song("Lalala"))
playlist.songs.add(Song("Lololo"))
box.put(playlist)
```## Table of Contents
- [Key Features](#key-features)
- [Getting started](#getting-started)
- [Gradle setup](#gradle-setup)
- [First steps](#first-steps)
- [Why use ObjectBox?](#why-use-objectbox-for-java-data-management)
- [Community and Support](#community-and-support)
- [Changelog](#changelog)
- [Other languages/bindings](#other-languagesbindings)
- [License](#license)## Key Features
🧠 **First on-device vector database:** easily manage vector data and perform fast vector search
🏁 **High performance:** exceptional speed, outperforming alternatives like SQLite and Realm in all CRUD operations.\
💚 **Efficient Resource Usage:** minimal CPU, power and memory consumption for maximum flexibility and sustainability.\
🔗 **[Built-in Object Relations](https://docs.objectbox.io/relations):** built-in support for object relations, allowing you to easily establish and manage relationships between objects.\
👌 **Ease of use:** concise API that eliminates the need for complex SQL queries, saving you time and effort during development.## Getting started
### Gradle setup
For Android projects, add the ObjectBox Gradle plugin to your root `build.gradle`:
```groovy
buildscript {
ext.objectboxVersion = "4.0.3"
repositories {
mavenCentral()
}
dependencies {
classpath("io.objectbox:objectbox-gradle-plugin:$objectboxVersion")
}
}
```And in your app's `build.gradle` apply the plugin:
```groovy
// Using plugins syntax:
plugins {
id("io.objectbox") // Add after other plugins.
}// Or using the old apply syntax:
apply plugin: "io.objectbox" // Add after other plugins.
```### First steps
Create a data object class `@Entity`, for example "Playlist".
```kotlin
// Kotlin
@Entity data class Playlist( ... )// Java
@Entity public class Playlist { ... }
```Now build the project to let ObjectBox generate the class `MyObjectBox` for you.
Prepare the BoxStore object once for your app, e.g. in `onCreate` in your Application class:
```java
boxStore = MyObjectBox.builder().androidContext(this).build();
```Then get a `Box` class for the Playlist entity class:
```java
Box box = boxStore.boxFor(Playlist.class);
```The `Box` object gives you access to all major functions, like `put`, `get`, `remove`, and `query`.
For details please check the [docs](https://docs.objectbox.io).
## Why use ObjectBox for Java data management?
ObjectBox is a NoSQL Java database designed for local data storage on resource-restricted devices, prioritizing
offline-first functionality. It is a smart and sustainable choice for local data persistence in Java and Kotlin
applications. It offers efficiency, ease of use, and flexibility.### Fast but resourceful
Optimized for speed and minimal resource consumption, ObjectBox is an ideal solution for mobile devices. It has
excellent performance, while also minimizing CPU, RAM, and power usage. ObjectBox outperforms SQLite and Realm across
all CRUD (Create, Read, Update, Delete) operations. Check out our [Performance Benchmarking App repository](https://github.com/objectbox/objectbox-performance).### Simple but powerful
With its concise language-native API, ObjectBox simplifies development by requiring less code compared to SQLite. It
operates on plain objects (POJOs) with built-in relations, eliminating the need to manage rows and columns. This
approach is efficient for handling large data volumes and allows for easy model modifications.### Functionality
💐 **[Queries](https://docs.objectbox.io/queries):** filter data as needed, even across relations\
💻 **[Multiplatform](https://docs.objectbox.io/faq#on-which-platforms-does-objectbox-run):** supports Android and JVM on Linux (also on ARM), Windows and macOS\
🌱 **Scalable:** handling millions of objects resource-efficiently with ease\
🦮 **Statically typed:** compile time checks & optimizations\
📃 **Automatic schema migrations:** no update scripts needed**And much more than just data persistence**\
🔄 **[ObjectBox Sync](https://objectbox.io/sync/):** keeps data in sync between devices and servers\
🕒 **[ObjectBox TS](https://objectbox.io/time-series-database/):** time series extension for time based data## Community and Support
❤ **Tell us what you think!** Share your thoughts through our [Anonymous Feedback Form](https://forms.gle/bdktGBUmL4m48ruj7).
At ObjectBox, we are dedicated to bringing joy and delight to app developers by providing intuitive and fun-to-code-with
APIs. We genuinely want to hear from you: What do you love about ObjectBox? What could be improved? Where do you face
challenges in everyday app development?**We eagerly await your comments and requests, so please feel free to reach out to us:**
- Add [GitHub issues](https://github.com/ObjectBox/objectbox-java/issues)
- Upvote important issues 👍
- Drop us a line via [@ObjectBox_io](https://twitter.com/ObjectBox_io/) or contact[at]objectbox.io
- ⭐ us on GitHub if you like what you see!Thank you! Stay updated with our [blog](https://objectbox.io/blog).
## Changelog
For notable and important changes in new releases, read the [changelog](CHANGELOG.md).
## Other languages/bindings
ObjectBox supports multiple platforms and languages.
Besides JVM based languages like Java and Kotlin, ObjectBox also offers:- [Swift Database](https://github.com/objectbox/objectbox-swift): build fast mobile apps for iOS (and macOS)
- [Dart/Flutter Database](https://github.com/objectbox/objectbox-dart): cross-platform for mobile and desktop apps
- [Go Database](https://github.com/objectbox/objectbox-go): great for data-driven tools and embedded server applications
- [C and C++ Database](https://github.com/objectbox/objectbox-c): native speed with zero copy access to FlatBuffer objects## License
```text
Copyright 2017-2024 ObjectBox Ltd. All rights reserved.Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License athttp://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
```Note that this license applies to the code in this repository only.
See our website on details about all [licenses for ObjectBox components](https://objectbox.io/faq/#license-pricing).