CakePHP 中文教程3

第五章 Scaffolding (脚手架?)

Scaffolding是一个很棒的途径,使得早期开发的部分web应用能够运行起来。早期的数据库模式是不稳定的,很容易变化。Scaffolding有个下降趋势:web程序员憎恨创建以后可能根本用不到的forms。为了减少程序员的这种重复劳动,
Cake中包含了Scaffolding。Scaffolding分析数据库,创建一些标准的使用add、delete、和edit按钮的lists,创建输入的forms,以及查看数据库中一个item的标准views。为了在程序中的controller中添加Scaffolding,需要添加$scaffold变量:

注意save操作是如何放置在一个条件语句中:如果你试图保存数据到model中,cake自动尝试确数据正确。可以查看第十章了解更多关于正确规则.如果不想查看正确性直接保存数据,使用save($data,false);
其他有用的保存方法:●savaFieldId($name,$value)
○保存一个单field的值●getLastInsertID()○返回最近创建记录的ID1.4
Model的Callbacks
在我们接近0.10.x最终版的时候,我们添加了一些model的回调函数,允许用户能够逻辑上悄悄的在model操作前或操作后执行。为了在应用中获得这种方法,在model中使用提供的参数,重载下面的这些方法●beforeFind○这个回调函数在一个查询操作开始之前执行。将查询前的操作逻辑放到这个方法里面。当你在model中重写这个方法时,当你想要find操作执行时候返回true,当你想要执行中止时候返回false●afterFind○使用这个回调函数可以修改从find操作中返回的结果,或者实现其他任何的find后逻辑。这个函数的参数是model的find操作的结果,返回的是修改后的结果。●beforeSave()○在这个函数中放置任何保存前的逻辑。如果你像保存操作执行则返回true,否则返回false●afterSave
○放置任何你想要在保存后执行的代码在这个回调函数中●beforeDelete
○放置删除前的逻辑代码。想要删除操作执行则返回true,否则返回false●afterDelete
○放置任何你想要在删除后执行的代码在这个回调函数中2. Model 变量
当你创建你的models时候,你可以设置一些特殊的变量,来获得对Cake函数的使用。●$primaryKey○如果这个model关联到一个数据库的table,而且数据库的主键并不是id,那么使用这个变量来告诉Cake主键的名字●$transactional○告诉Cake该model是否支持传输,设置为boolea值。●$useTable○如果你想使用的数据库的table并不是model名的复数形式,而且你也不想改变table名,设置这个变量为table名●$validate
○确认传递给model的数据是否正确的一个数组。查看第十章●$useDbConfig○还记得数据库设置中,你可以在/app/config/database.php文件中设置么?使用这个变量可以交换他们

classCategoriesControllerextendsAppController{var$scaffold;}有关Scaffold,要注意一个重要的问题:
Scaffold期望每个以_id结尾的filed
name是一个外键并且指向一个table,table的名称和_id前方的一样。所以,举个例子来说,如果你嵌套了分类,你最好有个列叫做parent_id。在这个版本中,最好能够命名为parentid.同样,在表中有一个外键,并且你已经合适的联结到models,在show/edit/newd的views中,选择的表将会和外键的表一起自动的表现出来。在foreign
model中设置$displayField来决定foreign中哪些field会被显示。继续我们的例子,category有个标题classTitleextendsAppModel{var$displayField=”title”;}

第六章 Models

本章内容:

  1. Model Function

1.1 用户定义的Function

1.2 检索(retrieving)你的数据

1.3 保存你的数据

1.4 Model的回调

  1. Model的变量

  2. Associations

Model是什么,它是MVC模式中的M

澳门新葡亰3522平台游戏,Model做些什么。它使得domain logic和presentation分隔开,独立application
logic(It separates domain logic from the presentation, isolating
application logic.)

一个Model概要的说就是一个指向数据库的access,更具体,就是数据库中的特定的table。默认的,每个model都使用自身名字复数形式的table,比如,User
Mode使用 users

table。Models可以维护数据特定的规则,联结信息以及它使用的table的方法。

1. Model的方法

从PHP的观点看,models都是从AppModel类继承来的类。类AppModel原始是定义在
/cake目录下。你也可以创建自己的放在
app/app_model.php.这个文件应该包含一些可供多个models共享的方法。AppModel本身也是从Model类继承而来的,Model类是一个标准的Cake库,定义在
libs/model.php

注意

虽然本节介绍的是Model中常用的方法,然而记住:更详细的参考请到

1.1 用户定义的方法

下面是model中一个特定table的例子,该例子实现了在blog中显示和隐藏两种方法

例6.1 Example Model Functions

?phpclassPostextendsAppModel{functionhide($id=null){if($id)$this-setId($id);$this-set(”hidden”,”1”);$this-save();}functionunhide($id=null){if($id)$this-setId($id);$this-set(”hidden”,”0”);$this-save();}}?

1.2 检索数据

下面是使用model得到数据的一些标准方法

●findAll($conditions,$fields,$order,$limit,$page,$recursive)

○返回特定的fields,fields由$limit(默认是50)个记录,匹配$conditions(如果有),从第$page(默认1)页开始列表,$conditions内容应该像SQL语句中的一样,比如:$conditions=race
= wookie AND thermal_detonators

○当$recursive选项设置成1到3的整数,findAll()将会试图返回在联结到该model中发现的所有项的models.这项递归寻找可以深入3层。

●find($conditions, $fields, $order, $recursive)

○返回匹配$conditions的第一条记录的制定的fields(如果没有指定则返回全部)

○$recursive作用同上

●findAllByFieldName($value) and findByFieldName($value)

○这些奇妙的方法可以用于指定特定的field和特定的value快速查找行,你要做的就是把你的field用驼峰表达法添加在后面。举个例子

$this-Post-findByTitle(”MyFirstBlogPost”);$this-Author-findByLastName(”Rogers”);$this-Property-findAllByState(”AZ”);$this-Specimen-findAllByKingdom(”Animalia”);

返回的结果是一个数组,和find()以及findAll()返回的结果是一个形式

●field($name,$conditions,$order)

○根据$order排序,根据条件$conditions,将第一条记录中的field值,作为string返回

●findCount($conditions)

○返回匹配$conditions的记录的个数

●generateList

($conditions=null,$order=null,$limit=null,$keyPath=null,$valuePath=null)

○根据models的lists,得到一系列key的值,特别是根据model
list创建selectlist。$conditions, $order,
$limit参数使用方法和上面相同。$keyPath和$valuePath是你告诉model那里去找keys和values来成list。举个例子,基于Role
model,你想生成一个由ids(类型integer)当作key,由roles当作value的list,这个方法调用形式如下:

$this-set(”Roles”,$this-Role-generateList(null,”role_nameASC”,null,”id”,”role_name”));//Thiswouldreturnsomethinglike:array(”1”=”AccountManager”,”2”=”AccountViewer”,”3”=”SystemManager”,”4”=”SiteVisitor”);

●read($fields=null, $id=null)

○使用这个方法从当前装载的记录或者由$id指定的记录中得到fields和值

特定的Sql调用可以使用model的findBySql()方法。举例,在blog应用中,我想存储一个发贴者的first
name到一个table中,但是这个table并不是我的cake
schema中的一部分。我就可以通过这个model中的一个特定的方法

例6.2 Custom Sql Calls With findBySql()

?phpclassPostextendsAppModel{functionposterFirstName(){$ret=$this-findBySql(SELECTfirst_nameFROMposters_tableWHEREposter_id=1);$firstName=$ret[0][”first_name”];return$firstName;}}?

当然也有query()方法,如果执行成功返回true,失败返回false。因为query语句并不是都返回结果集。比如DELETE
FROM problems WHERE solved = true

1.3 保存数据

为了保存你的数据到model中,你应该向model提供你想要保存的数据。这些数据提交给save()方法应该以下面的形式保存

Array([modelname]=Array([fieldname1]=value[fieldname2]=value))

从form表单提交的数据会自动排列成这种形式,并且放置到controller中的$this-params[data],因此,通过web的form表单保存数据非常简单。一个controller的编辑方法可能会像下面这样显示:

functionedit($id){//Note:Thepropertymodelisautomaticallyloadedforusat$this-property.//Checktoseeifwehaveformdataif(isset($this-params[”form”][”data”][”property”])){//Here”swherewetrytosaveourdataif($this-property-save($this-params[”data”])){//Showtheuserthatherdatahasbeensaved$this-flash(”Yourinformationhasbeensaved.”,”/properties/edit/”.$this-params[”data”][”property”][”id”],2);exit();}else{//Ifthedatacouldn”tbevalidated,showthevalidationerrors//andrepopulateformfieldswithsubmitteddata$this-set(”form”,$this-params[”data”]);$this-validateErrors($this-property);$this-render();}}//Ifnoformdatawassubmitted,justrendertheeditview$this-render();}