ThinkPHP的CURD方法及查询方法一览

PHP 21NN 4个月前 (05-24) 17次浏览 已收录 0个评论 扫描二维码

所谓 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’] = ‘[email protected]’;
$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 方法。如果叧是想简单创建一个数据对象,幵丌需要完成一些额外癿功能
癿话,可以使用 data 方法简单癿创建数据对象。

setInc 和 setDec 方法。对于统计字段(通常指的是数字类型)的更新:
$Model->setInc(‘score’,’id=5′,3); // 用户的积分加 3
$Model->setInc(‘score’,’id=5′); // 用户的积分加 1
$Model->setDec(‘score’,’id=5′,5); // 用户的积分减 5
$Model->setDec(‘score’,’id=5′); // 用户的积分减 1

D 删除:

delete->()删除数据
$User->where(‘status=0′)->order(‘create_time’)->limit(’5′)->delete();

Model 的其他常见方法:

order 方法:结果排序 例如:
order(‘id desc’)
排序方法支持对多个字段的排序
order(‘status desc,id asc’)
order 方法的参数支持字符串和数组,数组的用法如下:
order(array(‘status’=>’desc’,’id’))

limit 方法:结果限制
limit(’1,10′)
如果使用 limit(’10′) 等效于 limit(’0,10′)

page 方法:查询分页,Page 方法的用法和 limit 方法类似,格式为:
Page(‘page[,listRows]‘)
Page 表示当前的页数,listRows 表示每页显示的记录数。例如表示每页显示 10 条记录的情况下面,获取第 2 页的数据:
Page(’2,10′)
listRow 如果不写的话,会读取 limit(‘length’) 的值,例如表示每页显示 25 条记录的情况下面,获取第 3 页的数据:
limit(25)->page(3);
如果 limit 也没有设置的话,则默认为每页显示 20 条记录。

Join 方法:查询 Join 支持.Join 方法的参数支持字符串和数组,并且 join 方法是连贯操作中唯一可以多次调用的方法。例如:
$Model->join(‘ work ON artist.id = work.artist_id’)->join(‘card ON artist.card_id = card.id’)->select();
默认采用 LEFT JOIN 方式,如果需要用其他的 JOIN 方式,可以改成
$Model->join(‘RIGHT JOIN work ON artist.id = work.artist_id’)->select();

Distinct 方法:查询的 Disiinct 支持。查询数据的时候进行唯一过滤
$Model->Distinct(true)->select();

Relation 方法:关联查询支持
$Model->Relation(true)->select();

条件查询

$map->put(‘name’,’php’); //name=’php’

(‘name’,array(‘like’,’think’)); //name like ‘…’

(‘id’,array(‘in’,array(1,2,4)));

(‘id’,array(’10’,’3′,’or’)); //id>=10 or <=3

thinkphp 多表查询语句

1、table()函数
thinkphp 中提供了一个 table()函数,具体用法参考以下语句:
$list=$Demo->table(‘think_blog blog,think_type type’)->where(‘blog.typeid=type.id’)->field(‘blog.id as id,blog.title,blog.content,type.typename as type’)->order(‘blog.id desc’ )->limit(5)->select();
echo $Demo->getLastSql(); //打印一下 SQL 语句,查看一下

2、join()函数
看一下代码:
$Demo = M(‘artist’);
$Demo->join(‘RIGHT JOIN think_work ON think_artist.id = think_work.artist_id’ );
//可以使用 INNER JOIN 或者 LEFT JOIN 这里一定要注意表名的前缀!
echo $Demo->getLastSql(); //打印一下 SQL 语句,查看一下

附最简单的增删查改的代码
[php]
// 查询数据
public function index(){
$Form = M(“Form”);
$list = $Form->limit(5)->order(‘id desc’)->findAll();
$this->assign(‘list’,$list);
$this->display();
}
// 写入数据
public function insert() {
$Form = D(“Form”);
if($vo = $Form->create()) {
$list=$Form->add();
if($list!==false){
$this->success(‘数据保存成功!’);
}else{
$this->error(‘数据写入错误!’);
}
}else{
$this->error($Form->getError());
}
}

// 更新数据
public function update() {
$Form = D(“Form”);
if($vo = $Form->create()) {
$list=$Form->save();
if($list!==false){
$this->success(‘数据更新成功!’);
}else{
$this->error(“没有更新任何数据!”);
}
}else{
$this->error($Form->getError());
}
}
// 删除数据
public function delete() {
if(!emptyempty($_POST[‘id’])) {
$Form = M(“Form”);
$result = $Form->delete($_POST[‘id’]);
if(false !== $result) {
$this->ajaxReturn($_POST[‘id’],’删除成功!’,1);
}else{
$this->error(‘删除出错!’);
}
}else{
$this->error(‘删除项不存在!’);
}
}

</=3


乐趣公园 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:ThinkPHP 的 CURD 方法及查询方法一览
喜欢 (0)
[1353713598@qq.com]
分享 (0)
关于作者:
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址