如何在Android中使用SQLite中的SQLite?

ZiG*_*iGi 5 sqlite service android

令人遗憾的是,找到一个简单的代码行来做到这一点很困难"在我看来".

无论如何,问题是我有一个活动和服务的程序"我是新来的服务".
我可以从使用的活动中访问我的SQLite数据库

TheDB类:

public TheDB(Context context) {
    this.context = context;
    OpenHelper openHelper = new OpenHelper(this.context);
    this.db = openHelper.getWritableDatabase();
}
Run Code Online (Sandbox Code Playgroud)

然后我可以调用这些方法,例如

myActivity类:

private TheDB db;
bla... bla... bla...
this.db = new TheDB(this);
db.insertSomething(id, name);
Run Code Online (Sandbox Code Playgroud)

TheDB类(从myActivity调用的方法):

public void insertSomething(String id, String name){
    db.execSQL("INSERT into " + farmsTable
+ " (id, name)"
+ " Values "
+ " (" + id + ", '" + name  + "')");
}
Run Code Online (Sandbox Code Playgroud)

我希望能够做的就是从我的服务中调用TheDB的方法,就像我从myActivity那样.

我是否制作了新的构造函数?我是否改变了实例化的方式?

Cri*_*ian 7

只需按照您为活动执行的操作即可.您需要实例化的唯一内容TheDB是上下文; Activity是一个Context以及Service.

  • 这是我的代码:public class myService extends Service {public TheDB db; 上下文背景; @Override public void onCreate(){context = getApplicationContext(); this.db = TheDB(context); } (2认同)