服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服务器之家 - 编程语言 - PHP教程 - thinkPHP5框架闭包函数与子查询传参用法示例

thinkPHP5框架闭包函数与子查询传参用法示例

2019-09-16 16:27菜鸟没翅膀 PHP教程

这篇文章主要介绍了thinkPHP5框架闭包函数与子查询传参用法,结合实例形式分析了thinkPHP5闭包查询与参数传递相关操作技巧,需要的朋友可以参考下

本文实例讲述了thinkPHP5框架闭包函数用法。分享给大家供大家参考,具体如下:

普通使用

举个栗子:

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

上述栗子就是一个简单的where查询的闭包函数使用,使用匿名函数添加复杂条件查询,

最后执行的sql是:

// 加入上述代码写在user模型里,则执行的sql为:
select * from user where (id = 1 or id = 2);

复杂用法

其实闭包函数也不会复杂到哪去,无非带参数不带参数而已。举个栗子(上面的栗子加强下)

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

这也就是thinkphp 5 里怎么使用闭包查询传参数的方法,使用use 传入参数。

tp5闭包子查询传参方法

在channel表中查询status,channel_id,channel_name,account_level这些字段,且这些字段的channel_id不在adv_id为$id的表adv_channel_rule中:

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

tp5闭包子查询传参:

$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的原生写法:

$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);

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

延伸 · 阅读

精彩推荐
  • PHP教程Laravel框架基于ajax实现二级联动功能示例

    Laravel框架基于ajax实现二级联动功能示例

    这篇文章主要介绍了Laravel框架基于ajax实现二级联动功能,结合实例形式分析了Laravel框架ajax数据读取及联动菜单的构造与使用技巧,需要的朋友可以参考下...

    snow_small2842019-06-30
  • PHP教程php断点续传之文件分割合并详解

    php断点续传之文件分割合并详解

    这篇文章主要为大家详细介绍了php断点续传之文件分割合并,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    _xiaoxiong1312019-09-08
  • PHP教程ThinkPHP5 的简单搭建和使用详解

    ThinkPHP5 的简单搭建和使用详解

    这篇文章主要介绍了ThinkPHP5 的简单搭建和使用详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    K0rz3n4992019-08-29
  • PHP教程Thinkphp5框架使用validate实现验证功能的方法

    Thinkphp5框架使用validate实现验证功能的方法

    这篇文章主要介绍了Thinkphp5框架使用validate实现验证功能的方法,结合实例形式分析了tp5内置的对象validate实现验证的相关操作技巧,需要的朋友可以参考下...

    zhensg3662019-08-28
  • PHP教程PHP的PDO事务与自动提交

    PHP的PDO事务与自动提交

    今天小编就为大家分享一篇关于PHP的PDO事务与自动提交,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...

    php参考手册3502019-06-28
  • PHP教程PHP实现断点续传乱序合并文件的方法

    PHP实现断点续传乱序合并文件的方法

    这篇文章主要介绍了PHP实现断点续传乱序合并文件的方法,涉及php文件读写、传输、排序等相关操作技巧,需要的朋友可以参考下...

    luyaran4972019-09-08
  • PHP教程PHP获取星期几的常用方法小结

    PHP获取星期几的常用方法小结

    这篇文章主要介绍了PHP获取星期几的常用方法,结合实例形式分析了php使用date函数获取指定日期星期几的具体操作技巧与相关注意事项,需要的朋友可以参考下...

    天涯海角路4272019-07-16
  • PHP教程PHP与以太坊交互详解

    PHP与以太坊交互详解

    在这篇文章中我们给大家分享了关于PHP与以太坊交互的相关知识点内容,有兴趣的朋友们阅读下吧。...

    以太坊4802019-09-10