Laravel雄辩的查询JSON列与在哪里? - php

我在查询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) =…