Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/327.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Android应用程序在getWritableDatabase()或getReadableDatabase()上崩溃_Java_Android_Android Sqlite_Sqliteopenhelper - Fatal编程技术网

Java Android应用程序在getWritableDatabase()或getReadableDatabase()上崩溃

Java Android应用程序在getWritableDatabase()或getReadableDatabase()上崩溃,java,android,android-sqlite,sqliteopenhelper,Java,Android,Android Sqlite,Sqliteopenhelper,我是php开发人员,试图学习android,我试图建立一个数据库并插入一些数据 我已经学习了一些教程,但是当我使用getWritableDatabase()或getReadableDatabase()时,我的应用程序卡住了 下面是我创建的DBHelper的代码 包com.example.bootstart import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.da

我是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


    }
}
我的模拟器每次发射都会崩溃,所以我一直在用手机进行测试

如果有帮助的话,我的min SDK是8


非常感谢各位的帮助。

正如@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)"; 
然后我认为你的代码会执行。然而,我认为您需要在
活动
类中创建一些方法来从数据库获取数据。这并没有错,但更有效的方法如下

DBHelper类中创建方法
并使用
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();

只需在

private static final String COLUMN_ID = "id";

我总是在日志中打印代码中构造的db命令以进行检查,因为我总是在空格、括号或逗号方面出错。省去了很多心痛。

我不知道这是否是导致崩溃的原因,但您的CREATE语句无效。“id”后面没有空格,因此字符串将为。。“…idINTEGER初级…”。先修好,再试一次。@Larry,我真傻。成功了。谢谢你,拉里。把它当作答案,好吗P+1打印命令是了解查询实际将如何执行的一个好主意。很好的建议。真的节省了我几个小时。@ElaBuwa在数据库类中创建方法将允许您在许多活动中使用它,在大型应用程序中您将100%需要它。因此,现在养成好习惯比以后艰难地学习好。