运行以下代码时,我遇到一条错误消息,提示我在此行中使用了分号:
$select_stock->addExpression("REPLACE(b.corporateName, '&', '&')");
因为“&”号放置不正确
InvalidArgumentException:; SQL字符串不支持。一次只使用一个语句。
还有另一种解决方法吗?
public function c_form_db_2($cName) {
$select_stock = $this->connection->select('stock', 'a');
$select_stock->fields('a', ['high', 'low', 'stockname']);
$select_stock->innerJoin('stockdetails', 'b', 'b.high = a.high');
$select_stock->condition('a.isCurrentPrice', 'Yes');
$select_stock->condition('a.isActive', 'Yes');
$select_stock->condition('b.status', 'Closing');
$select_stock->addExpression("REPLACE(b.corporateName, '&', '&')");
$select_stock->escapeLike($cName);
$select_stock->orderBy('a.tickerId', 'DESC');
$select_stock->orderBy('a.volId', 'DESC');
$select_stock_rows = $select_stock->execute()
->fetchAll(\PDO::FETCH_ASSOC);
return $select_stock_rows;
}
答案 0 :(得分:0)
我不了解Drupal,但我认为REPLACE是标准的MySql函数,并且Drupal支持所有这些功能。在这种情况下,如果您偶然运行的是MySql 8 ,则不要使用REPLACE,而要使用REGEXP_REPLACE并与正则表达式“&amp”匹配。使用通配符“。”为了 ';'假定“;”为字符是唯一可以与通配符匹配的字符。