栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

SQLite扑朔迷离,数据库资产如何工作

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

SQLite扑朔迷离,数据库资产如何工作

首先,您需要从csv构建一个sqlite数据库。这可以通过以下方式完成:

  1. 创建必要的表(users.sql)
        CREATE TABLE users(       firstname TEXT NOT NULL,       lastname TEXT NOT NULL,       dob TEXT NOT NULL    );
  1. 创建sqlite数据库

    sqlite3 database.db < users.sql
  2. 插入CSV数据

        sqlite3 database.db    .mode csv    .import data.csv users
  1. 将database.db放入您的资产中,并将其添加到pubspec.yaml中。
        flutter:      # ...      assets:        - assets/database.db
  1. 在您的应用中,您必须将资产文件复制到“文档”中。这有点复杂。
        // Construct a file path to copy database to    Directory documentsDirectory = await getApplicationdocumentsDirectory();    String path = join(documentsDirectory.path, "asset_database.db");    // only copy if the database doesn't exist    if (FileSystemEntity.typeSync(path) == FileSystemEntityType.notFound){      // Load database from asset and copy      ByteData data = await rootBundle.load(join('assets', 'database.db'));      List<int> bytes = data.buffer.asUint8List(data.offsetInBytes, data.lengthInBytes);      // Save copied asset to documents      await new File(path).writeAsBytes(bytes);    }
  1. 最后,您可以像这样访问数据库。
        Directory appDocDir = await getApplicationdocumentsDirectory();    String databasePath = join(appDocDir.path, 'asset_database.db');    this.db = await openDatabase(databasePath);    initialized = true;
  1. 查询示例(this._initialize()是步骤6)
        Future<List<Page>> search(String word, int parentId) async {        if (!initialized) await this._initialize();        String query = '''          SELECt * FROM users          LIMIT 25''';        return await this.db.rawQuery(query);    }


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/415706.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号