SQLite Delete Cascade не работает: сбой ограничения FOREIGN KEY - PullRequest
1 голос
/ 13 июня 2019

У меня есть две таблицы:

Дочерняя таблица

 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 Ответ

1 голос
/ 13 июня 2019

В API 16+ необходимо включить ограничение внешнего ключа, например, в классе SQLITEOpenHelper:

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

Поскольку ограничение внешнего ключа включено, можно проверить, не ссылается ли другая таблица на дочернюю таблицу.и это внешний ключ не каскадный.Также ") REFERENCES " + TABLE_POST_NEW + "(_id) вы определили столбец _id в вашем TABLE_POST_NEW?

...