发布时间:2015-05-27 19:32:17作者:知识屋
所谓CURD。即对数据库操作的四个基本操作(CURD):C:create(创建)、U:update(更新)、R:read(读取)和D:detele(删除)。
在ThinkPHP中,并不是一定以这几个名字的方法,这里列出常见的:select,find,findAll,save,create等方法:
D读取:
select->()查询数据集,和findAll->()相同。例如:
$User->where(‘status=1′)->order(‘create_time’)->limit(10)->select();
注意:在连贯操作中除了select方法必须放到最后一个外,其他的连贯操作的方法调用顺序没有先后,例如,下面的代码和上面的等效:
$User->order(‘create_time’)->where(‘status=1′)->limit(10)->select();
如果丌习惯使用连贯操作 话,新版迓支持直接使用参数迕行查诟 方式。例如上面 代码可以改
写为:
$User->select(array('order'=>'create_time', 'where'=>'status=1', 'limit'=>'10'));
find->()方法,和以上两种方法类似。区别在只返回一条数据。可以和getField->()获取一条记录的某个字段值一起用。
select和findall效果一样,返回的是一个二维数组。如
array(1) {
[0] => array(8)
{ ["rank_id"] => string(3) “151″
["rank_name"] => string(7) “测试9″
["rank_memo"] => string(3) “123″
["uid"] => string(5) “59471″
["rank_kw"] => string(6) “重要”
["rank_uptime"] => string(10) “1280202914″
["isverify"] => string(1) “0″
["ishot"] => string(1) “0″
}
}
find的效果如下,返回的是一个一维数组:
array(8) {
["rank_id"] => string(3) “151″
["rank_name"] => string(7) “测试9″
["rank_memo"] => string(3) “123″
["uid"] => string(5) “59471″
["rank_kw"] => string(6) “重要”
["rank_uptime"] => string(10) “
1280202914″ ["isverify"] => string(1) “0″
["ishot"] => string(1) “0″
}
Where方法:用于查询或者更新条件的定义
Table方法:定义要操作的数据表名称
$Model->Table(‘think_user user’)->where(‘status>1′)->select();
field方法:定义要查询的字段
field方法的参数支持字符串和数组,例如,
$Model->field(‘id,nickname as name’)->select();
$Model->field(array(‘id’,'nickname’=>’name’))->select();
如果不使用field方法指定字段的话,默认和使用field(‘*’)等效。
U更新,C创建:
data,add,save方法:数据对象赋值,添加,保存。例如:
$data['name'] = ‘ThinkPHP’;
$data['email'] = ‘ThinkPHP@gmail.com’;
$Model->data($data)->add();//新增,相当于insert,连贯写法
$Model->add($data); //新增,相当于insert,非连贯写法
$Model->data($data)->where(‘id=3′)->save(); //修改,相当于update
需要注意的是,save方法的话,如果数据没有变化,那么默认返回的操作是FALSE。但是这个save执行是OK的,这个需要注意。
create->()自动从POST的字段组成形如$data的数据
$User=D("User");
$User->create(); //默认通过表单提交的数据进行创建
$User->add(); //新增
如果你 主键是自劢增长类型, 如果 入数据成功 话,Add方法 回值就是最新 入 主键值,可以直接获 。
使用data方法创建 数据对象丌会迕行自劢验证和过滤操作,请自行处理。但在迕行add戒者
save操作 候,数据表中丌存在 字段以及非法 数据类型(例如对象、数组等非标量数据)是会自
劢过滤 ,丌用担心非数据表字段 写入导致 SQL错诣 问题。
我们熟 令 验证、自劢验证和自劢完成(我们会在后面看 相关 用法)功能,其实都
必须通过create方法才能生效。Create方法创建 数据对象是保存在内存中, 没有实际写入 数据库
中,直 使用add戒者save方法。如果 是想简单创建一个数据对象, 丌需要完成一些额外 功能