All data stored in Hive is organized in boxes. A box can be compared to a table in SQL but it does not have a structure and can contain anything.
For a small app, a single box might be enough. For more advanced problems, boxes are a great way to organize your data. Boxes can also be encrypted to store sensitive data.
Before a box can be used, you have to open it:
var box = await Hive.openBox<E>('testBox');
The name of the box specifies the storage location and is used to check if a box already exists. It is case-insensitive.
The key has to be a byte array with length 32 and is used to encrypt and decrypt all values in the box.
By default, keys are sorted lexicographically. This parameters allows you to provide a custom sorting order.
Specify your own rules for automatic compaction.
If your app is killed while a write operations is running, the last entry might be corrupted. This entry will be deleted automatically when the app starts again. If you don't want this behaviour, you can disable it.
By default, all keys and values are stored in memory and read operations are synchronous (no disk access). By setting this to true, values are not cached and loaded asynchronously.
The optional type parameter specifies the type of the values in the box.
If the box is already open, it will be returned immediately. All supplied parameters will be ignored.
Once you obtained a box instance, you can read, write and delete entries.
Hive stores a reference to all open boxes. If you want to get an already opened box, you can use
var box = Hive.box('myBox');
This is especially useful for Flutter apps because you don't need to pass the box between widgets.
If you don't need a box again, you should close it. All cached keys and values of the box will be dropped from memory and the box file will be closed after all active read and write operations finished.
var box = await Hive.openBox('myBox');await box.put('hello', 'world');await box.close();
Before your application exits, you should call
Hive.close() to close all open boxes. Don't worry if the app is killed before you close Hive, it doesn't matter.
When you open a box, you can specify that it may only contain values of a specific type. For example a user box could be opened like this:
var box = await Hive.openBox<User>('users');box.add(User());box.add(5); // Compile time error
This box can also contain subtypes of
It is important that you provide the same type parameter to
Hive.box(). You cannot open the same box multiple times with different type parametes.
await Hive.openBox<User>('users');Hive.box<User>('users'); // OKHive.box('users'); // ERRORHive.box<Dog>('users'); // ERROR