繁体   English   中英

Android APP在getWritableDatabase()或getReadableDatabase()上崩溃

[英]Android APP crashes on getWritableDatabase() or getReadableDatabase()

我是php开发人员,尝试学习android,并且尝试设置数据库并插入一些数据。

我遵循了一些教程,但是当我使用getWritableDatabase()getReadableDatabase()时,我的应用程序卡住了。

以下是我创建的DBHelper的代码。

包com.example.bootstart;

import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.util.Log;

public class DBHelper extends SQLiteOpenHelper {
    private static final String LOGTAG = "THEDBHELPER";

    private static final String DATABASE_NAME = "geolocation.db";
    private static final int DATABASE_VERSION = 1;

    private static final String TABLE_LOCATIONS = "locations";
    private static final String COLUMN_ID = "id";
    private static final String COLUMN_welawa = "welawa";
    private static final String COLUMN_lati = "latitude";
    private static final String COLUMN_longi = "longitude";

    private static final String TABLE_CREATE = "CREATE TABLE " + TABLE_LOCATIONS + " ("  
            + COLUMN_ID + "INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_welawa + " TEXT, " + COLUMN_lati 
            + " TEXT, " + COLUMN_longi + " TEXT)"; 


    public DBHelper(Context context) {
        super(context, DATABASE_NAME, null, DATABASE_VERSION);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL(TABLE_CREATE);
        Log.i(LOGTAG, "TABLE HAS BEEN CREATED");
    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
        db.execSQL("DROP TABLE IF EXISTS " + TABLE_LOCATIONS);
        onCreate(db);
    }

}

我通过MainActivity类访问它。

package com.example.bootstart;

import android.os.Bundle;
import android.widget.Toast;
import android.app.Activity;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;


public class MainActivity extends Activity {
    SQLiteOpenHelper dbhelper;
    SQLiteDatabase database;
    @Override 
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Toast.makeText(getApplicationContext(), "Main Activity", Toast.LENGTH_LONG).show();

        dbhelper = new DBHelper(this);
            //Works upto here
        database = dbhelper.getReadableDatabase(); //App crashes on this line


    }
}

我的模拟器在每次启动时都会崩溃,因此我只能使用手机进行测试。

我的最小SDK是8,如果有帮助的话。

任何帮助都是非常感激的家伙。

只需在“ id”后的

private static final String COLUMN_ID = "id";

我总是在日志中打印在代码中构造的db命令,以检查是否总是出现空格,方括号或逗号错误。 节省很多心痛。

正如@Larry所建议的那样,您在查询中遇到了问题。 用这个

private static final String TABLE_CREATE = "CREATE TABLE " + TABLE_LOCATIONS + " ("  
            + COLUMN_ID + " INTEGER PRIMARY KEY AUTOINCREMENT, " + COLUMN_welawa + " TEXT, " + COLUMN_lati 
            + " TEXT, " + COLUMN_longi + " TEXT)"; 

然后,我认为您的代码将执行。 但是,我认为您想在Activity类中创建一些方法来从数据库中获取数据。 没错,但是更有效的方法如下。

DBHelper class创建您的方法,然后使用dbhelper.getReadableDatabase(); 那里。 例如,如果要获取表中的总记录。 将以下代码添加到您的DBHelper类中。

public int getTotalRecords() {
        SQLiteDatabase sqLiteDatabase = this.getReadableDatabase();
        Cursor cursor = sqLiteDatabase.query(TABLE_LOCATIONS, null, null, null, null, null, null, null);
        return cursor.getCount();
    }

然后在MainActivity获取总数。 像这样的记录

dbhelper = new DBHelper(this);
int count = dbhelper.getTotalRecords();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM