android – 在非Activity类中访问数据库

我有一些类(SomeClass.class).我想在其中有一些静态方法,如getAllDatabaseItems,getTableItems,insertNewRecord等.

如果我这样做的话

sqliteDatabase db = openOrCreateDatabase(DATABASE_NAME,MODE_PRIVATE,null);

>我需要扩展Activity(但仍然不能在静态方法中使用它)或在每个单独的方法(来自“调用者活动”)中传递“db”变量,这是非常笨重的.

什么是解决方案,所以我可以从一些类调用SomeClass.getAllDatabaseItems()?

@ MobileDev123所以我仍然需要扩展Activity(因为openOrCreateDatabase方法)?
如果我有这个类(实际上不是一个活动,我不会那样使用它)

public class Partner extends Activity {
@SuppressWarnings("static-access")
public Partner(Context mContext) {
    myContext = mContext;
    db = openOrCreateDatabase(DATABASE_NAME,myContext.MODE_PRIVATE,null);

    db.execsql("CREATE TABLE IF NOT EXISTS " + PARTNER_TABLE_NAME + " (id INTEGER PRIMARY KEY AUTOINCREMENT," + NAME + " VARCHAR);");
    db.execsql("CREATE TABLE IF NOT EXISTS " + ADDRESS_TABLE_NAME + " (id INTEGER PRIMARY KEY AUTOINCREMENT," + PARTNER_ID + " INT," + ADDRESS + " VARCHAR," + CITY + " VARCHAR);");
}

然后从我的一些活动中调用

    Partner newPartner = new Partner(this);
    partnersItems = newPartner.getAllItems();

我在第4行得到NullExceptionError(Partner.class) – 为什么?如果我使用静态参考

MODE_PRIVATE => (Context.MODE_PRIVATE)

再次它不起作用.

@Falmarri与static相同,如果我传入“this”参数(来自某个调用者类)并在静态方法中将其作为Context参数接收仍然无法成功创建/打开我的数据库(请参阅前面的行)

最佳答案
必须有一个叫你班级的活动或服务,你可以做的就是在方便的时候通过. (我更喜欢在构造函数中传递它).

在接收手上使用上下文瞬间.

例如,在MyActivity类中,您可以调用createDatabase(this)或new DataServices(this),但在DataServices类中,参数类型必须是上下文而不是MyActivity.

现在你有了context参数,你可以按照你想要的方式使用它,包括调用openOrCreateDatabase().

编辑:添加代码

来自Main.java

DataBase database = new DataBase(this); //This will pass an instance of main. Which is eventually the subclass of Context.java

在DataBase类中:您不需要在那里扩展活动.在构造函数中定义

public DataBase(Context context);
//如果你正在使用eclipse并依赖一些自动化工具,你可以看到类似Main main的东西.但是使用这些行,所以你可以通过传递它来从任何活动或服务中调用它.

定义Context类的字段,并将其引用到上下文arg.

喜欢this.localContext = context;

通过使用localContext变量,您可以调用openOrCreateDataBase列.

附加:如果您有任何控件(视图的子类)附加到此,您可以通过调用new DataBase(view.getContext())来实例化DataBase;

我希望这会对你有所帮助….如果需要更多帮助,请随时在下面发表评论.

相关文章

以下为个人理解,如错请评 CE: 凭据加密 (CE) 存储空间, 实际路径/data/user_ce/ DE: 设备加密 (DE) 存...
转载来源:https://blog.csdn.net/yfbdxz/article/details/114702144 用EventLog.writeEvent打的日志(或...
事件分发机制详解 一、基础知识介绍 1、经常用的事件有:MotionEvent.ACTION_DOWN,MotionEvent.ACTION...
又是好久没有写博客了,一直都比较忙,最近终于有时间沉淀和整理一下最近学到和解决的一些问题。 最近进...
Android性能优化——之控件的优化 前面讲了图像的优化,接下来分享一下控件的性能优化,这里主要是面向...
android的开源库是用来在android上显示gif图片的。我在网上查了一下,大家说这个框架写的不错,加载大的...