Android 错误无此表仅用于sqlite中的insert

Android 错误无此表仅用于sqlite中的insert,android,database,android-sqlite,Android,Database,Android Sqlite,我第一次使用sqlite数据库,但在插入数据时遇到了问题 我用DB浏览器创建了数据库,添加了3行,读取数据效果很好 我使用此选项选择所有行 public ArrayList<Vaca> selectAllVacas() { ArrayList<Vaca> list = new ArrayList<Vaca>(); Cursor cursor = this.db.query(VACAS_TABLE_NAME, null, nul

我第一次使用sqlite数据库,但在插入数据时遇到了问题

我用DB浏览器创建了数据库,添加了3行,读取数据效果很好

我使用此选项选择所有行

public ArrayList<Vaca> selectAllVacas() {
    ArrayList<Vaca> list = new ArrayList<Vaca>();
    Cursor cursor = this.db.query(VACAS_TABLE_NAME, 
        null, null, null, null, null, Vacas.NOMBRE+" ASC");
    if (cursor.moveToFirst()) {
         do {
             Vaca vaca = new Vaca(cursor.getLong(0), cursor.getString(1),
                  cursor.getString(2), cursor.getString(3), 
                  cursor.getInt(4), cursor.getInt(5), cursor.getInt(6));

            list.add(vaca);
         } while (cursor.moveToNext());
      }
      if (cursor != null && !cursor.isClosed()) {
     cursor.close();
  }
  return list;
}

选择WorkFine,我会得到数据,但是当我使用insert时,我会得到这个错误

 android.database.sqlite.SQLiteException: no such table: vacas (code 1): , while compiling: SELECT * FROM vacas WHERE numero_completo=?
我认为这是我的DBHelper类的一个问题,因为若存在用于选择的表,那个么也存在用于插入的表

我的整个DBHelper类如下

public class DBHelper extends SQLiteOpenHelper{

//Ruta por defecto de las bases de datos en el sistema Android


private static String DB_NAME = "vacas.db";

private static final String VACAS_TABLE_NAME = "vacas";

private SQLiteDatabase db;

private final Context myContext;

private String DB_PATH;

public static final class Vacas implements BaseColumns {
    private Vacas() {}
    public static final String NOMBRE = "nombre";
    public static final String NUMERO_CORTO = "numero_corto";
    public static final String NUMERO_COMPLETO = "numero_completo";
    public static final String FECHA_NACIMIENTO = "fecha_nacimiento";
    public static final String PADRE = "padre";
    public static final String MADRE = "madre";
}

public static final class Toros implements BaseColumns {
    private Toros() {}
    public static final String NOMBRE = "nombre";
}

public DBHelper(Context context) {
    super(context, DB_NAME, null, 1);
    this.myContext = context;
    ContextWrapper cw = new ContextWrapper(myContext);
    DB_PATH = cw.getFilesDir().getAbsolutePath()+ "/databases/";        
}

public void createDataBase() throws IOException{

    boolean dbExist = checkDataBase();
    if(dbExist){
    //la base de datos existe y no hacemos nada.
    }else{
    this.getReadableDatabase();

    try {
    copyDataBase();

    } catch (IOException e) {
    throw new Error("Error copiando Base de Datos");
    }
    }
}

private boolean checkDataBase(){

    SQLiteDatabase checkDB = null;

    try{

    String myPath = DB_PATH + DB_NAME;
    checkDB = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READONLY);

    }catch(SQLiteException e){

    //si llegamos aqui es porque la base de datos no existe todavía.

    }
    if(checkDB != null){

    checkDB.close();

    }
    return checkDB != null ? true : false;
}

/**
* Copia nuestra base de datos desde la carpeta assets a la recién creada
* base de datos en la carpeta de sistema, desde dónde podremos acceder a ella.
* Esto se hace con bytestream.
* */
private void copyDataBase() throws IOException{

    File folder = new File(DB_PATH);
    boolean success = true;
    if (!folder.exists()) {
        success = folder.mkdir();
    }

    //Abrimos el fichero de base de datos como entrada
    InputStream myInput = myContext.getAssets().open(DB_NAME);

    //Ruta a la base de datos vacía recién creada
    String outFileName = DB_PATH + DB_NAME;

    //Abrimos la base de datos vacía como salida
    OutputStream myOutput = new FileOutputStream(outFileName);

    //Transferimos los bytes desde el fichero de entrada al de salida
    byte[] buffer = new byte[1024];
    int length;
    while ((length = myInput.read(buffer))>0){
        myOutput.write(buffer, 0, length);
    }

    //Liberamos los streams
    myOutput.flush();
    myOutput.close();
    myInput.close();

}

public void open() throws SQLException{

    //Abre la base de datos
    try {
    createDataBase();
    } catch (IOException e) {
    throw new Error("Ha sido imposible crear la Base de Datos");
    }

    String myPath = DB_PATH + DB_NAME;
    db = SQLiteDatabase.openDatabase(myPath, null, SQLiteDatabase.OPEN_READONLY);

}

@Override
public synchronized void close() {
    if(db != null)
    db.close();
    super.close();
}

@Override
public void onCreate(SQLiteDatabase db) {
    try {
        createDataBase();
    } catch (IOException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
}

@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {

}

public ArrayList<Vaca> selectAllVacas() {
    ArrayList<Vaca> list = new ArrayList<Vaca>();
    Cursor cursor = this.db.query(VACAS_TABLE_NAME, 
        null, null, null, null, null, Vacas.NOMBRE+" ASC");
    if (cursor.moveToFirst()) {
         do {
             Vaca vaca = new Vaca(cursor.getLong(0), cursor.getString(1),
                  cursor.getString(2), cursor.getString(3), 
                  cursor.getInt(4), cursor.getInt(5), cursor.getInt(6));

            list.add(vaca);
         } while (cursor.moveToNext());
      }
      if (cursor != null && !cursor.isClosed()) {
     cursor.close();
  }
  return list;
}

public long insertVaca(Vaca vaca) {
  ContentValues values = new ContentValues();
  values.put(Vacas.NOMBRE, vaca.getNombre());
  values.put(Vacas.NUMERO_CORTO, vaca.getNumero_corto());
  values.put(Vacas.NUMERO_COMPLETO, vaca.getNumero_completo());
  values.put(Vacas.FECHA_NACIMIENTO, vaca.getFecha_nacimiento());
  values.put(Vacas.PADRE, vaca.getPadre());
  values.put(Vacas.MADRE, vaca.getMadre());
  db = this.getWritableDatabase();
  long id = db.insert(VACAS_TABLE_NAME, null, values);
  return id;
 }


 }
public类DBHelper扩展了SQLiteOpenHelper{
//在安卓系统的数据基础上进行缺陷检测
私有静态字符串DB_NAME=“vacas.DB”;
私有静态最终字符串VACAS\u TABLE\u NAME=“VACAS”;
专用数据库数据库;
私有最终上下文myContext;
私有字符串DB_路径;
公共静态最终类Vacas实现BaseColumns{
私有Vacas(){}
公共静态最终字符串NOMBRE=“NOMBRE”;
公共静态最终字符串NUMERO_CORTO=“NUMERO_CORTO”;
公共静态最终字符串NUMERO\u COMPLETO=“NUMERO\u COMPLETO”;
公共静态最终字符串FECHA_NACIMIENTO=“FECHA_NACIMIENTO”;
公共静态最终字符串PADRE=“PADRE”;
公共静态最终字符串MADRE=“MADRE”;
}
公共静态最终类Toros实现BaseColumns{
私有Toros(){}
公共静态最终字符串NOMBRE=“NOMBRE”;
}
公共DBHelper(上下文){
super(上下文,DB_名称,null,1);
this.myContext=上下文;
ContextWrapper cw=新的ContextWrapper(myContext);
DB_PATH=cw.getFilesDir().getAbsolutePath()+“/databases/”;
}
public void createDataBase()引发IOException{
布尔值dbExist=checkDataBase();
if(dbExist){
//达托斯的基地不存在。
}否则{
这是.getReadableDatabase();
试一试{
copyDataBase();
}捕获(IOE异常){
抛出新错误(“错误copiando Base de Datos”);
}
}
}
私有布尔校验数据库(){
SQLiteDatabase checkDB=null;
试一试{
字符串myPath=DB_PATH+DB_NAME;
checkDB=SQLiteDatabase.openDatabase(myPath,null,SQLiteDatabase.OPEN\u READONLY);
}catch(sqlitee异常){
//在没有托达维亚人的情况下,达托斯的基地是不存在的。
}
if(checkDB!=null){
checkDB.close();
}
return checkDB!=null?true:false;
}
/**
*科皮亚·努埃斯特拉(Copia nuestra)酒店
*西斯特马地毯基地,波德雷莫斯广场。
*这是我的梦想。
* */
私有void copyDataBase()引发IOException{
文件文件夹=新文件(DB_路径);
布尔成功=真;
如果(!folder.exists()){
success=folder.mkdir();
}
//阿布里莫斯·费切罗·德贝斯·德达托斯·科莫·恩塔达酒店
InputStream myInput=myContext.getAssets().open(DB_NAME);
//达托斯瓦西亚克雷达基地酒店
字符串outFileName=DB_路径+DB_名称;
//达托斯瓦西亚科莫萨利达基地酒店
OutputStream myOutput=新文件OutputStream(outFileName);
//塞利达市中心交通局
字节[]缓冲区=新字节[1024];
整数长度;
而((长度=myInput.read(缓冲区))>0){
写入(缓冲区,0,长度);
}
//利伯拉莫斯洛斯溪流酒店
myOutput.flush();
myOutput.close();
myInput.close();
}
public void open()引发SQLException{
//达托斯基地酒店
试一试{
createDataBase();
}捕获(IOE异常){
抛出新错误(“Ha sido impossible crear la Base de Datos”);
}
字符串myPath=DB_PATH+DB_NAME;
db=SQLiteDatabase.openDatabase(myPath,null,SQLiteDatabase.OPEN\u READONLY);
}
@凌驾
公共同步作废关闭(){
如果(db!=null)
db.close();
super.close();
}
@凌驾
public void onCreate(SQLiteDatabase db){
试一试{
createDataBase();
}捕获(IOE异常){
//TODO自动生成的捕捉块
e、 printStackTrace();
}
}
@凌驾
public void onUpgrade(SQLiteDatabase db,int-oldVersion,int-newVersion){
}
公共阵列列表selectAllVacas(){
ArrayList=新建ArrayList();
Cursor Cursor=this.db.query(VACAS\u TABLE\u NAME,
空,空,空,空,空,Vacas.NOMBRE+“ASC”);
if(cursor.moveToFirst()){
做{
Vaca Vaca=new Vaca(cursor.getLong(0),cursor.getString(1),
cursor.getString(2),cursor.getString(3),
cursor.getInt(4)、cursor.getInt(5)、cursor.getInt(6));
列表。添加(vaca);
}while(cursor.moveToNext());
}
if(cursor!=null&!cursor.isClosed()){
cursor.close();
}
退货清单;
}
公共长插页Vaca(Vaca-Vaca){
ContentValues=新的ContentValues();
value.put(Vacas.NOMBRE,vaca.getNombre());
value.put(Vacas.NUMERO_CORTO,vaca.getNumero_CORTO());
value.put(Vacas.NUMERO_COMPLETO,vaca.getNumero_COMPLETO());
value.put(Vacas.FECHA_-NACIMIENTO,vaca.getFecha_-NACIMIENTO());
value.put(Vacas.PADRE,vaca.getPadre());
value.put(Vacas.MADRE,vaca.getMadre());
db=this.getWritableDatabase();
long id=db.insert(VACAS\u TABLE\u NAME,null,value);
返回id;
}
}
我没有看到“createtable”sql语句。我看到您有一个表名,但没有表和期望驻留在一行中的值。比如:

private static final String DATABASE_CREATE6 = 
    "CREATE TABLE deviceTiles  (" +
            "_id               INTEGER PRIMARY KEY AUTOINCREMENT, " +
            "game_id           INTEGER REFERENCES games(_id) on UPDATE CASCADE," +
            "tile              INTEGER); " ;

db.execSQL(DATABASE_CREATE6);
解决方案 换行

db = this.getWritableDatabase();
long id = db.insert(VACAS_TABLE_NAME, null, values);
为此

long id = this.db.insert(VACAS_TABLE_NAME, null, values);

在inset“db.close();”关闭后关闭数据库,但存在相同的问题。如果您编辑了一个表列,请尝试卸载并安装您的应用程序。否,我没有更改任何表
我使用insert,我收到此错误
否。此错误与选择查询有关,而不是插入。我从资产复制了数据库,所以我不需要添加创建表否?它适用于select数据,因此创建了表。谢谢你的时间,我怀疑。我不认为你可以复制一个数据库/确保的方法是将你创建的数据库从设备(如果是根数据库)或你的模拟器中取出
long id = this.db.insert(VACAS_TABLE_NAME, null, values);