我有一些类(SomeClass.class).我想在其中有一些静态方法,如getAll
DatabaseItems,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参数接收仍然无法成功创建/打开我的数据库(请参阅前面的行)