Chinaunix首页 | 论坛 | 博客
  • 博客访问: 480351
  • 博文数量: 95
  • 博客积分: 2117
  • 博客等级: 大尉
  • 技术积分: 2301
  • 用 户 组: 普通用户
  • 注册时间: 2008-06-16 21:10
个人简介

辽宁铁岭人,现居大连。1970年生。 先后供职于 中国国际海运网、大连学堂科技、大连华仁视线网络科技有限公司、大连中科海云科技有限公司,任职技术总监。 精通PHP、JAVA、Javascript、HTML、CSS等网络编程技术及Linux操作系统。 精通面向对象编程、设计模式、重构及互联网产品设计。

文章分类

全部博文(95)

文章存档

2013年(31)

2012年(2)

2011年(34)

2010年(25)

2008年(3)

分类: PHP

2013-02-05 11:36:18

删除数据

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。

阅读(1016) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~