在android中执行getwritabledatabase()时出错

在android中执行getwritabledatabase()时出错,android,android-sqlite,getwritabledatabase,Android,Android Sqlite,Getwritabledatabase,我为数据库创建了一个类,为表和多个活动类创建了多个类。当我在活动类中使用数据库类实例时,一切正常,但同时当我在表类中使用数据库类实例时,只要控件转到getwritabledatabaseI,就运行应用程序我收到异常,应用程序退出,下面是所有3个类的代码 数据库类 public class Database extends SQLiteOpenHelper{ private static String dbname="Manager"; private static int d

我为数据库创建了一个类,为表和多个活动类创建了多个类。当我在活动类中使用数据库类实例时,一切正常,但同时当我在表类中使用数据库类实例时,只要控件转到
getwritabledatabase
I,就运行应用程序我收到异常,应用程序退出,下面是所有3个类的代码

数据库类

public class Database extends SQLiteOpenHelper{

    private static  String dbname="Manager";
    private static int dbversion=2;
    SQLiteDatabase db;

    public Database(Context context) {

        super(context, dbname, null, dbversion);
        // TODO Auto-generated constructor stub
        db=this.getWritableDatabase();
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        // TODO Auto-generated method stub
        StockTable st=new StockTable();
        db.execSQL(st.stocktable);
        }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub

    }

}
活动课

public class stockmanager extends Activity{

    String getentry=null;
    Database d=new Database(this);
    StockTable st=new StockTable();


    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.stockmanager);

    final Button AddStock=(Button) findViewById(R.id.button1);
        final EditText entry=(EditText) findViewById(R.id.editText1);
        final Button BroDetail=(Button) findViewById(R.id.button2);

        AddStock.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub
                getentry=entry.getText().toString();
                d.db.insert(st.tablename, null,st.insert());


            }
        });
                }
}
表类

    public class StockTable {

    Context c1;
    Database d1=new Database(c1);
    final String tablename="StockTable";
    private String column1="Stock_ID";
    private String column2="StockName";


    final String stocktable = "CREATE TABLE " + tablename + 
                " (" + column1+ " INTEGER PRIMARY KEY , " + column2 + " TEXT) ";

    public ContentValues insert(){

String select="Select StockID from Stocktable";

d.db.execsql(select);
        ContentValues cvi=new ContentValues();
        for(int i=0;i<=sm.getentry.length();i++)
        {
            cvi.put(column1, 1);
            cvi.put(column2,sm.getentry);
                        }

        return cvi;
    }

    public void delete(){


    }

StockID
Stock\u ID
是两个不同的列名

在创建表时,您使用
Stock\u ID
作为列,在启动select查询时,您使用
StockID
作为列,这是您的错误。您的查询应该是

String select="Select Stock_ID from Stocktable";
String select="Select Stock_ID from Stocktable";
还初始化了
上下文C1
。创建将当前
上下文
传递到
库存表
的构造函数,如:

public StockTable(Context cxnt){
this.c1=cxnt;
 }
public StockTable(Context cxnt){
this.c1=cxnt;
d1=new Database(c1);
 }

你应该把这个换掉

String select="Select StockID from Stocktable";

还初始化了
上下文C1
。创建将当前
上下文
传递到
库存表
的构造函数,如:

public StockTable(Context cxnt){
this.c1=cxnt;
 }
public StockTable(Context cxnt){
this.c1=cxnt;
d1=new Database(c1);
 }
再加上这个

 StockTable st=new StockTable(this);

进入您的
stockmanager
活动。

实例化StockTable时,这两行是一个问题:

Context c1;
Database d1=new Database(c1);
c1未初始化。。没有用于创建数据库的上下文。将有效的上下文传递给构造函数,或者使用“set”方法,然后实例化数据库以供使用。像这样:

public StockTable(Context context) {
 c1 = context;
 d1=new Database(c1);
}
我将替换:

String select="Select StockID from Stocktable";
与:


错误是因为您试图使用空上下文访问数据库。所以您需要在传递给数据库构造函数之前初始化c1

我只是编辑你的StockTable.java试试这个

import android.content.ContentValues;
import android.content.Context;

public class StockTable {

    Context c1;
    Database d1;
    final String tablename = "StockTable";
    private String column1 = "Stock_ID";
    private String column2 = "StockName";

    final String stocktable = "CREATE TABLE " + tablename + " (" + column1 + " INTEGER PRIMARY KEY , " + column2 + " TEXT) ";


    public StockTable(Context mContext){
        c1= mContext;
        d1= new Database(c1);
    }
    public ContentValues insert() {


        ContentValues cvi = new ContentValues();
        for (int i = 0; i <= sm.getentry.length(); i++) {
            cvi.put(column1, 1);
            cvi.put(column2, sm.getentry);
        }

        return cvi;
    }

    public void delete() {

    }
}
更新数据库类

public class Database extends SQLiteOpenHelper {

    private static String dbname = "Manager";
    private static int dbversion = 2;
    SQLiteDatabase db;
    private Context mContext;

    public Database(Context context) {

        super(context, dbname, null, dbversion);
        // TODO Auto-generated constructor stub
        mContext = context;
        db = this.getWritableDatabase();
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        // TODO Auto-generated method stub
        StockTable st = new StockTable(mContext);
        db.execSQL(st.stocktable);
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        // TODO Auto-generated method stub

    }

}

无论何时使用数据库和助手

Database database = new Database(this); 
在onCreate()之前,不能将类实例用作上下文。将数据库和数据库初始化推迟到onCreate()或更高版本

请参考以下内容,以便更好地理解:



@BirajZalavadia目前我没有日志,因此无法发布日志运行项目并获取日志文件。@Siva检查我的UpdateAnks以获取您的回复Jim但是如何将有效的上下文传递给android,我是一名android新手,您能解释更多关于这方面的信息吗
***
部分,我没有得到任何
getapplicationcontext
或类似的内容。我编辑了我的答案。此外,您的活动应该在onCreate:d=newdatabase(this);-其他答案提到了这一点,但你的评论是,它在那里工作,这让我相信,它是好的方式,即使它看起来是错误的…@M D我已经尝试过了,但是当控件转到
getwritabledatabase
时,我仍然得到了例外情况。Anks肯定会尝试一下。我已经尝试过了,但是当控件转到
getwritabledatabase
时,我仍然得到了例外情况,我现在无法尝试,但会使用代码并发布回答。我试过你们的建议,但现在在我为股票表创建对象的数据库类中,提示输入上下文,但我应该在那个里输入什么,因为数据库类中并没有上下文。请帮助我更新答案。谢谢@Biraj问题是数据库类第一类在我的问题中我为股票表创建了对象在那里它正在考虑上下文在这种情况下该怎么做。我用logcat通过问题更新了上面的错误。。你能告诉我有什么问题吗。
Database database = new Database(this);