阅读 83

thinkphp5.1 Array to string conversion问题 where express error:问题

thinkphp5.1构建查询数组,$where可以是二位数组或三维数组,
Db::table(‘think_user‘)
    ->where([
        [‘name‘, ‘like‘, $name . ‘%‘],
        [‘title‘, ‘like‘, ‘%‘ . $title],
        [‘id‘, ‘>‘, $id],
        [‘status‘, ‘=‘, $status],
    ])
    ->select();

$map = [
        [‘name‘, ‘like‘, ‘thinkphp%‘],
        [‘title‘, ‘like‘, ‘%thinkphp‘],
        [‘id‘, ‘>‘, 0],
    ];
Db::table(‘think_user‘)
    ->where([ $map ])
    ->where(‘status‘,1)
    ->select();
发现构建查询数组时,如果要指定数字下标,第一个下标必须是0,源码  thinkphp\library\think\db\Builder.php 305行
if (key($value) !== 0) {
throw new Exception(‘where express error:‘ . var_export($value, true));
}

原文:https://www.cnblogs.com/jackduan/p/14832535.html

文章分类
代码人生
版权声明:本站是系统测试站点,无实际运营。本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 XXXXXXo@163.com 举报,一经查实,本站将立刻删除。
相关推荐