替换与与&

时间:2019-06-19 15:05:58

标签: mysql drupal-8

运行以下代码时,我遇到一条错误消息,提示我在此行中使用了分号:

$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;
}

1 个答案:

答案 0 :(得分:0)

我不了解Drupal,但我认为REPLACE是标准的MySql函数,并且Drupal支持所有这些功能。在这种情况下,如果您偶然运行的是MySql 8 ,则不要使用REPLACE,而要使用REGEXP_REPLACE并与正则表达式“&amp”匹配。使用通配符“。”为了 ';'假定“;”为字符是唯一可以与通配符匹配的字符。