Flutter——数据库Drift开发详细教程(二)

目录

1.核心API

1.1查询数据列表分页

限制返回的结果数量limit ,从某一位置开始查询offset

dart 复制代码
///limit=10, offset=10
Future<List<TodoItem>> limitTodos(int limit, {int? offset}) {
  return (select(todoItems)..limit(limit, offset: offset)).get();
}

1.2 列表排序

使用该orderBy方法。它需要一个函数列表,用于从表中提取各个排序项。您可以使用任何表达式作为排序项。

dart 复制代码
///根据对象字段title,字母排序
  Future<List<TodoItem>> sortEntriesAlphabetically() {
    return (select(todoItems)
          ..orderBy([
            // (t) => OrderingTerm(expression: t.title, mode: OrderingMode.desc),
            (t) => OrderingTerm(expression: t.title),
          ]))
        .get();
  }
  ///下图是结果,左1  mode: OrderingMode.desc 反向排序
  ///左2 默认顺序排序

1.3推迟获取与观察

如果您希望使查询可作为Future或 来使用,则可以使用其中一个抽象基类Stream来优化返回类型;Selectable ,返回数据对象或者流类型 自行选择

dart 复制代码
// Exposes `get` and `watch`
MultiSelectable<TodoItem> pageOfTodos(int page, {int pageSize = 10}) {
  return select(todoItems)..limit(pageSize, offset: page);
}

// Exposes `getSingle` and `watchSingle`
SingleSelectable<TodoItem> selectableEntryById(int id) {
  return select(todoItems)..where((t) => t.id.equals(id));
}

// Exposes `getSingleOrNull` and `watchSingleOrNull`
SingleOrNullSelectable<TodoItem> entryFromExternalLink(int id) {
  return select(todoItems)..where((t) => t.id.equals(id));
}
相关推荐
涤生大数据4 分钟前
海量数据存储与分析:HBase vs ClickHouse vs Doris 三大数据库优劣对比指南
数据库·clickhouse·hbase
shenyan~11 分钟前
关于Python:7. Python数据库操作
数据库
sunly_15 分钟前
Flutter:组件10、倒计时
开发语言·javascript·flutter
长流小哥17 分钟前
MySQL数据操作全攻略:DML增删改与DQL高级查询实战指南
数据库·mysql
麓殇⊙25 分钟前
MySQL--索引入门
android·数据库·mysql
苦学编程啊30 分钟前
深入理解Redis SDS:高性能字符串的终极设计指南
数据库·redis·缓存·c#
时序数据说32 分钟前
时序数据库IoTDB单机版、双活版与集群版的区别
大数据·数据库·时序数据库·iotdb
Chan1633 分钟前
Redis从入门到实战实战篇2
java·数据库·redis·spring·lua
深山技术宅37 分钟前
Redis TLS 加密对性能的影响分析
数据库·redis·缓存
星火1913141 小时前
DBeaver连接人大金仓数据库V9
数据库