Laravel:'on clause' 中的未知列 $parameter
Laravel: Unknown column $parameter in 'on clause'
我在 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
当您使用联接连接两个表时,您必须指定列名($bar 必须等于列名字符串)。所以如果你想发送一些参数数据,你必须使用 where
而不是 on
.
->join('foo AS f1', function($join) use ($bar)
{
$join->on('f1.foo', '=', 'f2.foo')
->where('f1.bar', '=', $bar);
})
我在 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
当您使用联接连接两个表时,您必须指定列名($bar 必须等于列名字符串)。所以如果你想发送一些参数数据,你必须使用 where
而不是 on
.
->join('foo AS f1', function($join) use ($bar)
{
$join->on('f1.foo', '=', 'f2.foo')
->where('f1.bar', '=', $bar);
})