本地存储Android应用数据。RoomLibrary的替代方法。
创始人
2024-11-29 06:00:28
0

在Android应用中,有多种方法可以将数据存储到本地而不使用Room Library。以下是两个常见的替代方案:

  1. SharedPreferences:这是一个快速且简单的方法来存储和检索键值对。数据存储在用户设备上,可以在应用间共享。以下是使用SharedPreferences存储和检索数据的示例代码:

存储数据:

SharedPreferences preferences = getSharedPreferences("MY_APP", Context.MODE_PRIVATE);
SharedPreferences.Editor editor = preferences.edit();
editor.putString("USER_NAME", "John Doe");
editor.putInt("USER_AGE", 30);
editor.apply();

检索数据:

SharedPreferences preferences = getSharedPreferences("MY_APP", Context.MODE_PRIVATE);
String userName = preferences.getString("USER_NAME", "");
int userAge = preferences.getInt("USER_AGE", 0);
  1. SQLite数据库:这是一个轻量级数据库,与Room Library类似,但更为基础。使用SQLite,您可以创建表格,全面处理CRUD操作,并将数据存储在设备上。以下是使用SQLite存储和检索数据的示例代码:

创建数据库:

public class MyDatabaseHelper extends SQLiteOpenHelper {
    private static final String DATABASE_NAME = "MY_APP.db";
    private static final int DATABASE_VERSION = 1;

    public MyDatabaseHelper(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        String sql = "CREATE TABLE USERS " +
                "(ID INTEGER PRIMARY KEY AUTOINCREMENT, " +
                "NAME TEXT, " +
                "AGE INTEGER)";

        db.execSQL(sql);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        db.execSQL("DROP TABLE IF EXISTS USERS");
        onCreate(db);
    }
}

存储数据:

MyDatabaseHelper dbHelper = new MyDatabaseHelper(this);
SQLiteDatabase db = dbHelper.getWritableDatabase();

ContentValues values = new ContentValues();
values.put("NAME", "John Doe");
values.put("AGE", 30);

long newRowId = db.insert("USERS", null, values);

检索数据:

MyDatabaseHelper dbHelper = new MyDatabaseHelper(this);
SQLiteDatabase db = dbHelper.getReadableDatabase();

String[] projection = {"ID", "NAME", "AGE"};

Cursor cursor = db.query(
        "USERS",                     
        projection,                 
        null,                      
        null,                      
        null,                     
        null,                     
        null                      
);

if (cursor != null) {
    cursor.moveToFirst();

相关内容

热门资讯

线上(wepoke真的)原来是... 线上(wepoke真的)原来是真的有挂!其实真的有挂(2022已更新)(哔哩哔哩);亲,其实确实真的...
两教程(Wepoke程序)软件... 两教程(Wepoke程序)软件透明挂辅助工具(软件透明挂)透视辅助(2024已更新)(哔哩哔哩);致...
软件(wepoke透明)原来是... 软件(wepoke透明)原来是真的有挂!其实真的有挂(2020已更新)(哔哩哔哩)是一款可以让一直输...
一模拟器(德扑工具)外挂辅助工... 一模拟器(德扑工具)外挂辅助工具(透视)透视辅助(2025已更新)(哔哩哔哩);亲真的是有正版授权,...
系统(aapoker讲解)竟然... 系统(aapoker讲解)竟然真的有挂!其实真的有挂(2021已更新)(哔哩哔哩);aapoker讲...
6系统(aapoker下载)外... 6系统(aapoker下载)外挂辅助工具(辅助挂)透视辅助(2023已更新)(哔哩哔哩)aapoke...
智能(德扑之星刷数据)果真真的... 智能(德扑之星刷数据)果真真的有挂!原来真的有挂(2025已更新)(哔哩哔哩);《WPK辅助透视》‌...
1机器人(德州nzt软件)软件... 1机器人(德州nzt软件)软件透明挂辅助软件(透视)透视辅助(2022已更新)(哔哩哔哩);人气非常...
ai代打(德扑之星决策)确实是... ai代打(德扑之星决策)确实是真的有挂!原来真的有挂(2020已更新)(哔哩哔哩);科技详细教程小薇...
第8透明(wepoke数据)外... 第8透明(wepoke数据)外挂透明挂辅助神器(辅助挂)透视辅助(2023已更新)(哔哩哔哩);原来...