Java 在SQLITE数据库中找不到表

Java 在SQLITE数据库中找不到表,java,android,sqlite,Java,Android,Sqlite,我面临着这个奇怪的问题,我搜索了很多,但到目前为止没有用 下面的代码使用从openhelper类扩展的DBHelper检索SQLite数据库 public class DBHelper extends SQLiteOpenHelper { public static final int DB_VERSION = 1; public static final String DB_NAME = "cp.db"; public static final String DB_PATH = "/data

我面临着这个奇怪的问题,我搜索了很多,但到目前为止没有用

下面的代码使用从openhelper类扩展的DBHelper检索SQLite数据库

public class DBHelper extends SQLiteOpenHelper {

public static final int DB_VERSION = 1;
public static final String DB_NAME = "cp.db";
public static final String DB_PATH = "/data/data/abdulla.com.test/databases/";
public static final String ID = "no";
public static final String NAME = "name";
public static final String FORMULA = "formula";
public static final String MW = "mw";
public static final String OMEGA = "omega";
public static final String TC = "tc";
public static final String PC = "pc";
SQLiteDatabase db;
Cursor cursor;
ArrayList<String> elementName;

public DBHelper(Context context) {
    super(context, DB_NAME, null, DB_VERSION);
}

@Override
public void onCreate(SQLiteDatabase db) {

}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
    db.execSQL("drop table if exists elements");
    this.onCreate(db);

}


public List<Element> getAllElements() {
    List<Element> elementList = new ArrayList<Element>();
    // Select All Query
    Cursor cursor = null;
        String selectQuery = "SELECT  * FROM elements";
        SQLiteDatabase db = this.getReadableDatabase();
        cursor = db.rawQuery(selectQuery, null);

    // looping through all rows and adding to list
    if (cursor.moveToFirst()) {
        do {
            Element element = new Element();
            element.setNo(Integer.parseInt(cursor.getString(0)));
            element.setFormula(cursor.getString(1));
            element.setName(cursor.getString(2));

            // Adding contact to list
            elementList.add(element);
        } while (cursor.moveToNext());
    }

    // return contact list
    return elementList;
}
}
我知道元素表在那里


有什么帮助吗?

问题可能出在您的onUpgrade方法中。若数据库并没有版本,应用程序将尝试升级它,并删除表db.execSQLdrop table If exists elements


解决方案:或更改onUpgrade方法delete DROP语句。

表创建代码在哪里?我正在从android中现有的cp.db文件读取数据。在代码之前,我手动填充了数据库。@FrankN.Stein我还需要创建一个表吗?您必须将预加载的数据库复制到正确的位置,在这里您将在搜索中找到该位置。很多人使用一个名为Sqlite资产的库Helper@e4c5你什么意思?
public class MainActivity extends AppCompatActivity {


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    DBHelper helper = new DBHelper(this);

    List<Element> elementList = helper.getAllElements();

    for(Element element : elementList){
        String log = "no: "+element.getNo();

        Log.d("No: ", log);
    }

 }
}
java.lang.RuntimeException: Unable to start activity 
ComponentInfo{abdulla.com.test/abdulla.com.test.MainActivity}: 
android.database.sqlite.SQLiteException: no such table: elements (code 1):  
, while compiling: SELECT  * FROM elements