在CentOS系统中,Flutter的数据存储可以通过多种方式实现,包括SharedPreferences、文件存储、SQLite数据库等。以下是一些基本的操作方法:
SharedPreferences是一种轻量级的数据存储方式,适用于存储简单的键值对数据。
首先,确保你的Flutter项目中已经添加了shared_preferences
插件。如果没有,可以在pubspec.yaml
文件中添加:
dependencies:
flutter:
sdk: flutter
shared_preferences: ^2.0.15
然后运行flutter pub get
来安装依赖。
import 'package:shared_preferences/shared_preferences.dart';
Future<void> saveData(String key, String value) async {
final prefs = await SharedPreferences.getInstance();
await prefs.setString(key, value);
}
Future<String?> getData(String key) async {
final prefs = await SharedPreferences.getInstance();
return prefs.getString(key);
}
Future<void> deleteData(String key) async {
final prefs = await SharedPreferences.getInstance();
await prefs.remove(key);
}
Flutter提供了dart:io
库来处理文件存储。
import 'dart:io';
import 'package:path_provider/path_provider.dart';
Future<File> getFile() async {
final directory = await getApplicationDocumentsDirectory();
return File('${directory.path}/example.txt');
}
Future<void> writeFile(String content) async {
final file = await getFile();
await file.writeAsString(content);
}
Future<String> readFile() async {
final file = await getFile();
return await file.readAsString();
}
Future<void> deleteFile() async {
final file = await getFile();
await file.delete();
}
SQLite是一种轻量级的嵌入式数据库,适用于需要复杂查询和数据结构的应用。
首先,确保你的Flutter项目中已经添加了sqflite
插件。如果没有,可以在pubspec.yaml
文件中添加:
dependencies:
flutter:
sdk: flutter
sqflite: ^2.0.0+4
path_provider: ^2.0.2
然后运行flutter pub get
来安装依赖。
import 'package:sqflite/sqflite.dart';
import 'package:path/path.dart';
Future<Database> openDatabase() async {
final databasePath = join(await getDatabasesPath(), 'my_database.db');
return await openDatabase(databasePath,
version: 1, onCreate: _onCreate);
}
Future _onCreate(Database db, int version) async {
await db.execute('''
CREATE TABLE my_table(
id INTEGER PRIMARY KEY,
name TEXT NOT NULL,
age INTEGER NOT NULL
)
''');
}
Future<int> insertData(Map<String, dynamic> row) async {
final db = await openDatabase();
return await db.insert('my_table', row);
}
Future<List<Map<String, dynamic>>> queryData() async {
final db = await openDatabase();
return await db.query('my_table');
}
Future<int> updateData(Map<String, dynamic> row) async {
final db = await openDatabase();
return await db.update('my_table', row,
where: 'id = ?', whereArgs: [row['id']]);
}
Future<int> deleteData(int id) async {
final db = await openDatabase();
return await db.delete('my_table', where: 'id = ?', whereArgs: [id]);
}
通过这些方法,你可以在CentOS系统中的Flutter应用中实现数据的存储和管理。根据具体需求选择合适的数据存储方式。