Каскадное удаление строк в SQL — это опция внешнего ключа, которая автоматически удаляет все дочерние записи в ссылающейся таблице при удалении родительской записи в указанной таблице. 6 Для этого используется конструкция ON DELETE CASCADE. 16
Запрещение удаления в SQL достигается с помощью конструкции ON DELETE NO ACTION. 14 Она предотвращает какие-либо действия в зависимой таблице при удалении или изменении связанных строк в главной таблице. 2 Если есть связанные данные в таблице-потомке, то вернётся ошибка, иначе запись успешно удалится. 1
Таким образом, отличие в том, что каскадное удаление позволяет удалять данные из таблицы, не нарушая ограничение внешнего ключа, а запрещение удаления предотвращает любые действия в зависимой таблице при удалении или изменении связанных строк в главной таблице.