0

我一直在尝试在我的 android 项目中使用 sqlite 创建一个数据库,但不明白为什么我会收到这个消息错误“没有这样的表”:S 我以为我正在创建一个好的数据库。有什么帮助吗?

这是我的代码 handler_sqlite 类:

public class Handler_sqlite extends SQLiteOpenHelper {

    public Handler_sqlite(Context ctx)
    {
        super ( ctx, "MiBase", null, 1);

    }

    @Override
    public void onCreate(SQLiteDatabase db ) 
    {
        String query =  " CREATE TABLE IF NOT EXISTS usuarios ( user VARCHAR PRIMARY KEY, password VARCHAR );" ;
        db.execSQL(query);

    }

    @Override
    public void onUpgrade(SQLiteDatabase db, int version_ant, int version_post)
    {
        db.execSQL("DROP TABLE IF EXISTS usuarios");
        onCreate(db);
    }

    public void insertarReg(String user, String password)
    {
        ContentValues valores = new ContentValues();
        valores.put("user", user);
        valores.put("password", password);
        this.getWritableDatabase().insert("usuarios",null,valores);

    }

    public void abrir()
    {
        this.getWritableDatabase();
    }

    public void cerrar()
    {
        this.close();
    }

    public String leer_user ()
    {
        String columnas[]={"user","password"};
        Cursor c = this.getReadableDatabase().query("usuarios",columnas,null,null,null,null,null);
        int iu;
        iu = c.getColumnIndex("user");

        c.moveToLast();
        return c.getString(iu);
    }

    public String leer_password ()
    {
        String columnas[]={"user","password"};
        Cursor c = this.getReadableDatabase().query("usuarios",columnas,null,null,null,null,null);
        int ip;
        ip = c.getColumnIndex("password");

        c.moveToLast();
        return c.getString(ip);
    }

}

以及我引用 bd 的主要代码:

Handler_sqlite helper = new Handler_sqlite(this);
 helper.abrir();
helper.insertarReg(username,passw);
String username2 = helper.leer_user();
String password2 = helper.leer_password();

当前错误:

插入密码时出错= x用户= y android.database.sqlite.SQLiteException:没有这样的表:usuarios,编译时:INSERT INTO usuarios(密码,用户)值(?,?);

提前致谢。

4

2 回答 2

1

当您将数据库的名称传递给构造函数时,它应该包含 .db 扩展名(即 MiBase.db)。

于 2013-10-03T15:23:34.953 回答
0

你确定创建表语句是正确的吗?(即 exec 不会抛出任何异常/错误/等)。

数据库真的存在吗?如果您 adb shell 并作为您的应用程序运行,请查看 db 目录(名称可能因版本而异)并查看是否有 usaios.sqlite 文件。

您确定所有代码中的表名都没有拼写错误吗?(即使用一个常量而不是重新输入它)

于 2013-10-03T14:53:47.570 回答