thinkphp_内置与自定义方法使用_已迁移

原创
2015/09/28 17:34
阅读数 78
  1. 这条语句有多表联查(join)、别名(alias)、字段(field)、数据限制(limit)、按序(order) 方法使用实例

$data = $this->alias('a')->field('a.*,a.create_time as au_create_time,a.status as au_status,a.project_id as au_project_id,p.*,r.*')->join('__PROJECT__ as p ON a.project_id = p.id')->join('__PROJECT_ROLE__ as r ON a.role_id = r.id')->where(array('a.uid'=>$uid,'a.is_delete'=>0,'a.status'=>$s))->order('a.create_time DESC')->limit(6)->select();

   数据库内置函数

$result= $relation->distinct(true)->where($data1)->getField('bid',true);//去重复,获取品牌

   获取最后执行的SQL语句

M()->getLastSql(); //写在最后执行文件中



 2.实例其它控制器

    A方法用于在内部实例化控制器,调用格式:
A('[项目://][分组/]模块','控制器层名称') 
最简单的用法:

    $User = A('User');

    表示实例化当前项目的UserAction控制器(这个控制器对应的文件位于Lib/Action/UserAction.class.php),如果采用了分组模式,并且要实例化另外一个Admin分组的控制器可以用:

    $User = A('Admin/User');

    也支持跨项目实例化(项目的目录要保持同级)

    $User = A('Admin://User');

    表示实例化Admin项目下面的UserAction控制器
3.1版本增加了分层控制器的支持,所以还可以用A方法实例化其他的控制器,例如:

    $User = A('User','Event);

    实例化UserEvent控制器(对应的文件位于Lib/Event/UserEvent.class.php)。
实例化控制器后,就可以调用该控制器中的方法,不过需要注意的情况是,在跨项目调用的情况下,如果你的操作方法 有针对当前控制器的特殊变量操作,会有一些未知的问题,所以,一般来说,官方建议需要公共调用的控制器层单独开发,不要有太多的依赖关系。

    


自定义方法

  1. 模板调用自写的方法  参数

{:get_picture($data['head_img'],'path')}



OT通用分页方法----多表查询分页时

$data = $this->lists('member',$comdi,'audition_num','uid');
$model = M()->table(__MEMBER__.' m')->join('LEFT JOIN __RESUME_TERM__ r ON r.id = m.uid');



展开阅读全文
打赏
0
0 收藏
分享
加载中
更多评论
打赏
0 评论
0 收藏
0
分享
返回顶部
顶部