快速业务通道

有关数据检索的更多内容

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-03-16

find()方法接受两个参数:$type(类型)和$constraints(约束)。$type(类型)是一个用来定义查询“类型”的字符串。$type可以设成下面这三种类型中的一个

  • all:find方法会按照给定的排序方式和个数限制返回所有符合条件的记录。
  • first:这个方法只返回符合约束条件的首条记录
  • count:会返回查询结果中所包含记录的总数量。

正如我们从上一个例子中所看到那样,我们可以以关联数组(associative array)的形式在第二个参数 $constraints中指定其他查询约束。$constraints参数的关联数组可以有如下键(key)

  • conditions(条件):条件(conditions)可应用于取代查询语句中的WHERE子句。默认值是1=1,这表示没条件约束。
  • fields(字段):查询结果应该返回的字段范围。如果没有指明,它会返回所有字段。当find()函数的第一个参数$type被设置成count时,该参数不可用。
  • order(排序):这个字符串定义了查询语句中ORDER BY子句的内容。如果order排序没有指明,那么SQL查询中将不会添加有ORDER BY子句。查询类型是count是,该参数也不可用。
  • limit(限制):该整数指明了返回记录的最大数量。如果没指定limit,那么函数会返回所有符合条件的记录。只有当查询类型是all时,它才可用。
  • offset(偏移值):这个参数定义了首个返回记录的偏移值。默认值是0.只有当type参数是all时,该设置才有效。

为了便于读者更清楚地了解这个概念,我们将会快速浏览下面这些表明了find()用法的例子:

1,如果你想知道书名以字母“A”开头的书的数目,我们会在BooksController(Books控制器中)添加如下代码:

$count = $this->Book->find(''count'', array(''conditions'' =>  
            array(''Book.title'' => ''LIKE A%''));
It executes the following SQL query:

它会执行如下SQL查询

 SELECT COUNT(*) AS `count` FROM `books` AS `Book` WHERE  
       `Book`.`title` LIKE ''A%'';

find()方法的$type参数设置成count时,查询返回的结果是一个整数。在这个例子中, $count变量的值可能是2.

2,如果我们想查询id最大书本所对应的书号(ISBN)和书名,我们会使用下面这个代码

 

$book = $this->Book->find(''first'',
       &

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号