在SQLite Android中发现“没有这样的表”错误

时间:2011-07-02 00:05:51

标签: java android sqlite

我正在尝试了解SQLite数据库,但我真的很讨厌处理任何后端的东西,充满激情。我已经用一个看似简单的问题撞墙了。

以下是我认为来自DatabaseHelper

的代码
public class DatabaseHelper extends SQLiteOpenHelper {
    private static final String DATABASE_NAME = "Library";

    public static final String TABLE_NAME = "books";
    public static final String TITLE = "title";
    public static final String AUTHOR = "author";
    public static final String ISBN = "isbn";

    public DatabaseHelper(Context context) {
        super(context, DATABASE_NAME, null, 1);
    }

    @Override
    public void onCreate(SQLiteDatabase db) {
        db.execSQL("CREATE TABLE " + TABLE_NAME + " (id INTEGER PRIMARY KEY AUTOINCREMENT, title TEXT, author TEXT, isbn TEXT)");
    }


    public boolean insertBook(String title, String author, String isdn) {

        try {
            SQLiteDatabase db = getWritableDatabase();

            ContentValues cv = new ContentValues();
            cv.put(TITLE, title);
            cv.put(AUTHOR, author);
            cv.put(ISBN, isdn);

            db.insert(TABLE_NAME, null, cv);
            db.close();

            return true;
        } catch (Exception exp) {
            exp.printStackTrace();

            return false;
        }
    }
}

这是我主要活动中的代码

dbHelper = new DatabaseHelper(this);

dbHelper.insertBook("Harry Potter", "JK", "1000");
dbHelper.insertBook("Hamlet", "Shakespeare", "500");

Eclipse告诉我insertBook()方法中存在错误。它说有no such table books: ...。我不知道我在这里做错了什么。让它更令人沮丧的是,在它工作完美之前只有几分钟,然后(我认为)我放弃了表,它只是因为某种原因再次创建它,即使这个代码自我第一次创建以来没有改变(我想......)。

10 个答案:

答案 0 :(得分:38)

您的设备上有一个旧版本的数据库,它有(空)数据库,但没有books表。如果这是您的选择,只需卸载并重新安装该应用程序。

稍后,如果您想在最终用户设备上生产期间向数据库添加新表,但保留现有数据,则添加新表,更改架构或升级数据的指定挂钩是{{ 1}} onUpgrade

的方法

答案 1 :(得分:5)

我为此编写了一个ORM框架。 https://github.com/ahmetalpbalkan/orman

您可以使用SQLite轻松编写Android应用程序。它使用您的Java类(在本例中为Book)作为数据库表(实体)。

它甚至会自动创建您的表格,您只需说book1.insert(),已完成。

答案 2 :(得分:2)

您必须卸载该应用程序,然后重新安装。它应该在那之后工作。

答案 3 :(得分:1)

试试这个 例如对于插入:

 public boolean insertBook(String title, String author, String isdn) {

        try {
            SQLiteDatabase db = getWritableDatabase();

            ContentValues cv = new ContentValues();
            cv.put(TITLE, title);
            cv.put(AUTHOR, author);
            cv.put(ISBN, isdn);

            ***try
             {
            db.insert(TABLE_NAME, null, cv);
}
 catch ( SQLiteException e)
        {
            onCreate(db);
  db.insert(TABLE_NAME, null, cv);
}***

            db.close();

            return true;
        } catch (Exception exp) {
            exp.printStackTrace();

            return false;
        }
    }

答案 4 :(得分:0)

如果出于某种原因,您删除了表,则可能需要删除数据库以强制应用程序正确地重新创建它。使用adb shell并在/data/data/[package_name]/databases/中查找数据库。你可以删除该文件。

答案 5 :(得分:0)

我遇到了这个问题,但清理项目并没有修复它 结果我通过了DATABASE_NAME而不是TABLE_NAME

答案 6 :(得分:0)

确保调用onCreate方法。创建多个表时,我也遇到了类似的问题。如果您创建一个单独的类,请确保首先清除应用程序的所有存储数据,然后再次运行它。它对我来说很好。

答案 7 :(得分:0)

由于表从数据库的一开始就存在,因此没有任何意义,因此我们尝试了不同的操作:

  
      
  1. 卸载应用

  2.   
  3. 分段缓存/数据

  4.   
  5. 更改数据库版本号

  6.   
  7. 即使数据库已经存在,也要强制复制

  8.   

答案 8 :(得分:-1)

db.execSQL(
    "CREATE TABLE " + TABLE_NAME + " (id INTEGER PRIMARY KEY AUTOINCREMENT, title TEXT, author TEXT, isbn TEXT)"
);

删除表名后面的空格,应该是这样的。

db.execSQL(
    "CREATE TABLE " + TABLE_NAME + "(id INTEGER PRIMARY KEY AUTOINCREMENT, title TEXT, author TEXT, isbn TEXT)"
);

答案 9 :(得分:-1)

据我所知,您必须添加到要在Sqliteopenhelper class中访问的外部数据库的路径,请参见以下代码段

public final static String DATABASE_PATH = "/data/data/com.example.shortcuts/databases/";
com.example.shortcuts=Your Package name