亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

thinkPHP5框架閉包函數(shù)與子查詢(xún)傳參用法示例

 更新時(shí)間:2018年08月02日 14:51:23   作者:菜鳥(niǎo)沒(méi)翅膀  
這篇文章主要介紹了thinkPHP5框架閉包函數(shù)與子查詢(xún)傳參用法,結(jié)合實(shí)例形式分析了thinkPHP5閉包查詢(xún)與參數(shù)傳遞相關(guān)操作技巧,需要的朋友可以參考下

本文實(shí)例講述了thinkPHP5框架閉包函數(shù)用法。分享給大家供大家參考,具體如下:

普通使用

舉個(gè)栗子:

$this->where(function ($query)
{
 $query->where('id', 1)->whereor('id', 2);
})->find();

上述栗子就是一個(gè)簡(jiǎn)單的where查詢(xún)的閉包函數(shù)使用,使用匿名函數(shù)添加復(fù)雜條件查詢(xún),

最后執(zhí)行的sql是:

// 加入上述代碼寫(xiě)在user模型里,則執(zhí)行的sql為:
select * from user where (id = 1 or id = 2);

復(fù)雜用法

其實(shí)閉包函數(shù)也不會(huì)復(fù)雜到哪去,無(wú)非帶參數(shù)不帶參數(shù)而已。舉個(gè)栗子(上面的栗子加強(qiáng)下)

$this->where(function ($query) use ($id1, $id2)
{
 $query->where('id', $id1)->whereor('id', $id2);
})->find();

這也就是thinkphp 5 里怎么使用閉包查詢(xún)傳參數(shù)的方法,使用use 傳入?yún)?shù)。

tp5閉包子查詢(xún)傳參方法

在channel表中查詢(xún)status,channel_id,channel_name,account_level這些字段,且這些字段的channel_id不在adv_id為$id的表adv_channel_rule中:

$model = new Model();
$id = $req_models["id"];

tp5閉包子查詢(xún)傳參:

$res = $model->table('channel')
  ->field(['status','channel_id','channel_name','account_level'])
  ->where('channel_id','NOT IN',function($query) use ($id) {
 $query->table('adv_channel_rule')->where("adv_id",$id)->field('channel_id');
  })->select();

mysql的原生寫(xiě)法:

$res = 'SELECT adv_id,adv_name,status,account_level FROM `channel` WHERE channel_id NOT IN (SELECT channel_id FROM adv_channel_rule WHERE adv_id='.$id.')';
$result = $model->query($res);

更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《ThinkPHP入門(mén)教程》、《thinkPHP模板操作技巧總結(jié)》、《ThinkPHP常用方法總結(jié)》、《codeigniter入門(mén)教程》、《CI(CodeIgniter)框架進(jìn)階教程》、《Zend FrameWork框架入門(mén)教程》及《PHP模板技術(shù)總結(jié)》。

希望本文所述對(duì)大家基于ThinkPHP框架的PHP程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論