所谓CURD。即对数据库操做的四个基本操做(CURD):C:create(建立)、U:update(更新)、R:read(读取)和D:detele(删除)。
在ThinkPHP中,并非必定以这几个名字的方法,这里列出常见的:select,find,findAll,save,create等方法:php
D读取:
select->()查询数据集,和findAll->()相同。例如:
$User->where(‘status=1′)->order(‘create_time’)->limit(10)->select();
注意:在连贯操做中除了select方法必须放到最后一个外,其余的连贯操做的方法调用顺序没有前后,例如,下面的代码和上面的等效:
$User->order(‘create_time’)->where(‘status=1′)->limit(10)->select();thinkphp
find->()方法,和以上两种方法相似。区别在只返回一条数据。能够和getField->()获取一条记录的某个字段值一块儿用。数据库
select和findall效果同样,返回的是一个二维数组。如数组
array(1) {函数
[0] => array(8)测试
{ ["rank_id"] => string(3) “151″ui
["rank_name"] => string(7) “测试9″spa
["rank_memo"] => string(3) “123″对象
["uid"] => string(5) “59471″blog
["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(); //新增
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多表查询语句
一、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语句,查看一下
二、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语句,查看一下