SQLite删除级联不起作用:FOREIGN KEY约束失败

时间:2019-06-13 16:37:42

标签: java android database android-sqlite

我有两个表:

子表

 public static final String SQL_CREATE_TAB_COMMENT = "CREATE TABLE " +TABLE_COMMENT+ "( " + KEY_COMMENT + "  INTEGER PRIMARY KEY AUTOINCREMENT , " + COLUMN_EMMET + " TEXT NOT NULL , " +COMMENT+  " TEXT , "+IMAGCOM+" TEXT , "+FORMAT+" TEXT NOT NULL , "+DATECMTCREATION+" TEXT , "+TAGSTATUTCMT+" TEXT , "+ COLUMN_COMMENT_KEY_POST +" INT NOT NULL , "+EMETPOST_PHONE+ " TEXT, " +DEST_PHONE+ " TEXT, "  + IDCMTEMET + " TEXT,"+VISITEDCMT+" TEXT, "+TAB_IMAGES + " TEXT, "+IS_DOWNLOADED + " TEXT,"+FILEDOC+" TEXT,  FOREIGN KEY(" + COLUMN_COMMENT_KEY_POST + ") REFERENCES " + TABLE_POST_NEW + "(_id)  ON DELETE CASCADE )";

父表

  public static final String SQL_CREATE_TAB_POST_NEW = "CREATE TABLE " +TABLE_POST_NEW+ "( " +KEY_POST+ " INTEGER PRIMARY KEY AUTOINCREMENT ," +EMMET+ " TEXT NOT NULL , " +TEXT+  " TEXT NOT NULL , "+ IMAG +" TEXT ,"+TYPE+ " TEXT ," +DEST+ " TEXT ," +IDPOSTEMET+ " TEXT NOT NULL, " +CMT_NON_LU+ " TEXT, " +DATELASTEVENT+" TEXT, " +DATECREATION+ " TEXT, " +TAGSTATUT+ " TEXT,"+COUNTER_DEST+" TEXT,"+VISITED+" TEXT,"+ NAME_GROUP+ " TEXT,"+ IDGROUP + " TEXT, "+TAB_IMAGES + " TEXT, "+IS_DOWNLOADED +" TEXT, "+COLUMN_POST_KEY_CONTACT+ " INT NOT NULL DEFAULT 0, "+LABEL_IMAGES+" TEXT,"+TAB_FILE+" TEXT)";

现在,如果我要删除父行,则会出现此错误:

  

FOREIGN KEY约束失败,错误代码:787(SQLITE_CONSTRAINT_FOEIGNKEY)       原因:由于违反约束而中止

 public PosteManager openForWrite(){

    db = dbHelper.getWritableDatabase();
    //db.execSQL("PRAGMA foreign_keys=ON");
    db.setForeignKeyConstraintsEnabled(true);
    return this;
}

public int deletePoste(int posteId){

    openForWrite();
    int delete = db.delete(DbHelper.TABLE_POST_NEW, DbHelper.KEY_POST + "=" + posteId, null);
    close();

    return delete;

}
  

KEY_POST = _id;然后我测试COLUMN_COMMENT_KEY_POST = _id和COLUMN_COMMENT_KEY_POST = post_id

我有同样的错误

我测试了您的代码,并且在Log.d("TABLESQL","The creation SQL for table "中有此代码:

D/TABLESQL: The creation SQL for table comment_tbl_new is 
    CREATE TABLE comment_tbl_new( _commentid  INTEGER PRIMARY KEY AUTOINCREMENT , Emetteur TEXT NOT NULL , comment TEXT , imageCom TEXT , format TEXT NOT NULL , Datecmtcreation TEXT , Tagstatutcmt TEXT , post_id INT NOT NULL , emetPost_phone TEXT, Dest_phone TEXT, idcmtemet TEXT,visited TEXT, tab_image TEXT, idownloaded TEXT,filedoc TEXT,  FOREIGN KEY(post_id) REFERENCES post_tbl_new(_id) )
06-14 00:11:06.845 18468-18468/com. D/TABLESQL: The creation SQL for table comment_tbl is 
    CREATE TABLE comment_tbl( _commentid  INTEGER PRIMARY KEY AUTOINCREMENT , Emetteur TEXT NOT NULL , comment TEXT , imageCom TEXT , format TEXT NOT NULL , Datecmtcreation TEXT , Tagstatutcmt TEXT , _id INT NOT NULL , emetPost_phone TEXT, Dest_phone TEXT, idcmtemet TEXT,visited TEXT, tab_image TEXT, idownloaded TEXT,filedoc TEXT,  FOREIGN KEY(_id) REFERENCES post_tbl_new(_id)  ON DELETE CASCADE )

1 个答案:

答案 0 :(得分:1)

从API 16+开始,您应该在SQLITEOpenHelper类中启用外键约束:

@Override
public void onConfigure(SQLiteDatabase db){
    db.setForeignKeyConstraintsEnabled(true);
}

由于启用了外键约束,因此您可以检查另一个表是否未引用子表,并且它的外键是否不是级联的。还") REFERENCES " + TABLE_POST_NEW + "(_id)_id中定义了TABLE_POST_NEW列吗?