我在查询json列时遇到问题。
以前我的代码是
$query->whereIn('user', $users);
现在,我已将数据库类型更改为JSON列,并尝试修改新版本的代码。
在RAW MYSQL中,这有效
JSON_CONTAINS(user, '"tom","Bill"')
但是,当我用雄辩的/ php形式表示它时,它会不断失败或返回提示。在这里,我传入一个用户数组,以前使用的是在原始SQL中工作的WhereIn
$leads->whereRaw("JSON_CONTAINS(user, '"$users"')")
任何想法如何使它在Laravel中工作,这样我就可以传递字符串数组,并针对包含字符串数组的json列查询它们。
我的Json Colum拥有这样的数据
["Paul", "Tom", "Bob"]
参考方案
MySQL需要JSON字符串:
$leads->whereRaw('JSON_CONTAINS(user, ?)', [json_encode($users)])
在Laravel 5.6.24中,您可以使用whereJsonContains()
:
$leads->whereJsonContains('user', $users)
PHP:从函数返回值并直接回显它? - php这可能是一个愚蠢的问题,但是……的PHPfunction get_info() { $something = "test"; return $something; } html<div class="test"><?php echo get_info(); ?></div> 有没有办…
PHP getallheaders替代 - php我正在尝试从服务器上的apache切换到nginx。唯一的问题是我在PHP脚本中使用的getallheaders()函数,该函数不适用于Nginx。我已经尝试过用户在getallheaders函数上的php站点上提供的注释,但这并不返回所有请求标头。请告诉我如何解决这个问题。我真的想切换到Nginx。 参考方案 您仍然可以使用它,但是您必须像这里一样重新定义…
php-printf和sprintf具有不同的输出 - php我编写了以下微型php程序来测试printf和sprintf:<?php $str_1 = printf("%x%x%x", 65, 127, 245); $str_2 = sprintf("%x%x%x", 65, 127, 245); echo $str_1 . "\n"; echo $s…
Laravel 5中带有文件的Ajax表单提交 - php我正在尝试在laravel 5中实现fileupload。但是首先要发送数据,例如简单的字符串。我的表格: {!!Form::open(["url"=>"/photos", "method" => "post", "files"=>true,…
PHP:将字符串拆分为字母和数字部分的最佳方法 - php我有几个格式的字符串AA11 AAAAAA1111111 AA1111111 分离字符串的字母和数字部分的最佳方法(最有效)? 参考方案 如果它们都是一系列字母,然后是一系列数字,并且没有非字母数字字符,那么sscanf()可能比regexp更有效$example = 'AAA11111'; list($alpha,$numeric) =…