3

我在 Laravel 的数据库查询和参数绑定中使用参数时遇到了麻烦。

我收到此错误:

Error: "Column not found: 1054 Unknown column '3' in 'on clause'"

这是查询的一部分:

->join('foo AS f1', function($join) use ($bar)
      {
           $join->on('f1.foo', '=', 'f2.foo')
                ->on('f1.bar', '=', $bar);
      })

如果我这样做,它会起作用:

->on('f1.bar', '=', DB::raw($bar));

有什么办法解决这个问题?我当然也想为此使用参数绑定。但是,当我这样做时:

->on('f1.bar', '=', ':bar', ['bar' => $bar]);

我明白了:

ErrorException in Grammar.php line 196:
Array to string conversion
4

1 回答 1

5

当您使用连接连接两个表时,您必须指定列名($bar 必须等于列名字符串)。所以如果你想发送一些参数数据你必须where使用on

->join('foo AS f1', function($join) use ($bar)
      {
           $join->on('f1.foo', '=', 'f2.foo')
                ->where('f1.bar', '=', $bar);
      })
于 2017-07-06T15:12:58.590 回答