Isar NoSQL数据库:为Flutter量身打造的高性能数据库
1. 项目介绍
Isar 是一个为 Flutter 设计的超高速、易用的 NoSQL 数据库。它具有高度的可扩展性、丰富的功能、完全异步的操作,并且是多平台的,支持 iOS、Android 和桌面应用。Isar 数据库以其出色的性能、一致性的 ACID 语义、静态类型检查和美丽的文档而受到开发者们的青睐。
2. 项目快速启动
添加依赖
首先,在 pubspec.yaml
文件中添加 Isar 的依赖:
dependencies:
isar:
version: 3.1.8
hosted: https://pub.isar-community.dev/
定义数据模型
定义一个数据模型,例如一个 Email 类:
@collection
class Email {
final int id = Isar.autoIncrement;
late String title;
late List<Recipient> recipients;
@enumerated
late Status status;
}
@embedded
class Recipient {
late String name;
late String address;
}
enum Status { draft, pending, sent }
打开数据库
在应用启动时打开一个 Isar 数据库实例:
final dir = await getApplicationDocumentsDirectory();
final isar = await Isar.open([EmailSchema], directory: dir.path);
查询数据库
使用 Isar 的查询功能检索数据:
final emails = await isar.emails
.filter()
.titleContains('awesome', caseSensitive: false)
.sortByStatusDesc()
.limit(10)
.findAll();
3. 应用案例和最佳实践
CRUD 操作
Isar 提供了基本的 CRUD 操作,以下是如何使用它们:
final newEmail = Email()..title = 'Amazing new database';
await isar.writeTxn(() {
await isar.emails.put(newEmail); // 插入或更新
});
final existingEmail = await isar.emails.get(newEmail.id!); // 获取
await isar.writeTxn(() {
await isar.emails.delete(existingEmail.id!); // 删除
});
数据库查询
Isar 的查询语言允许使用索引、过滤对象、使用复杂数组逻辑,并且能够排序结果:
final importantEmails = isar.emails
.where()
.titleStartsWith('Important')
.limit(10)
.findAll();
final specificEmails = isar.emails
.filter()
.recipient((q) => q.nameEqualTo('David'))
.or()
.titleMatches('*university*', caseSensitive: false)
.findAll();
4. 典型生态项目
Isar 社区支持多个生态项目,例如:
- Isar Generator:用于生成 Isar 的数据模型代码。
- Isar Flutter Libs:包含了 Isar 核心库。
- Isar Inspector:一个实时检查 Isar 实例和集合的工具。
Isar 生态项目为开发者提供了丰富的工具和库,以简化数据库集成和使用过程。
创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考