• 技术文章 >php教程 >php手册

    CakePHP 2.x CookBook 中文版 第七章 模型 之 删除数据

    2016-06-13 10:54:30原创388

    删除数据

    CakePHP 的模型类提供了几种从数据库中删除记录的方法。

    delete

    delete(int $id = null, boolean $cascade = true);

    通过 $id 删除记录。默认情况下,同时删除那些依赖于被删除记录的记录。

    例如,删除一个与许多 Recipe 记录相关的 User 记录(User ‘hasMany’ 或者 ‘hasAndBelongsToMany’ Recipes):

    如果 $cascade 设置为 true,相关的 Recipe 记录也被删除(模型的 dependent-value 设置为 true)。

    如果 $cascade 设置为 false,User 删除后,Recipe 记录仍被保留。

    如果数据库支持外键和级联删除,会比 CakePHP 的级联更优先被依赖。使用 Model:delete() 的级联特性的好处之一是它允许你使用行为和模型的回调:

    1 $this->Comment->delete($this->request->data('Comment.id'));

    你可以使用同时存在于模型和行为中的 beforeDelete 和 afterDelete 向删除过程挂接自定义逻辑。更多信息请参见回调方法。

    deleteAll

    deleteAll(mixed $conditions, $cascade = true, $callbacks = false)

    除了 deleteAll() 将删除所有与提供的条件相匹配的记录之外,它与 delete() 基本一样。$conditions 数组将以 SQL 片段或数组的形式提供。

    conditions 要匹配的条件

    cascade 逻辑值,设置为 true,删除时将同时删除有依赖关系的记录。

    callbacks 逻辑值,运行回调

    成功时返回 True,失败时挽回 False。

    示例:

    1 // 删除所用的条件与 find() 相同

    2 $this->Comment->deleteAll(array('Comment.spam' => true), false);

    如果删除带有回调 和/或 级联,将查找相关行并删除。这常常会导致发出多条查询。

    注解

    当删除条件成功执行但没有记录匹配时,即使没有记录被删除,deleteAll() 也将返回 true。

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:PHP扩展生成器 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • php利用新浪接口查询ip获取地理位置• php mysql 数据库类• PHP代码:Http断点续传的实现例子• 聊天室php&mysql(二)• 基于php实现七牛抓取远程图片
    1/1

    PHP中文网