原则本机 SQL 查询更新


doctrine native sql query update

我需要帮助。 我需要使用原则 1.2 获取更新 sql 查询的结果

用谷歌搜索了一下,我找到了一种使用原则进行本机SQL查询的方法

$preparequerystring = "UPDATE mdw_reportes_operacion SET mmaplicado = 2.742495126705653 WHERE id = 5294;";
         $con = Doctrine_Manager::getInstance()->connection();
         $st = $con->executeUpdate($preparequerystring,array(false));
         print_r($st);
我想

知道如何检索有关我正在执行的查询的一些信息。我试过

$result = $st->fetch(); 

但它返回 500 内部服务器错误。

执行 UPDATE 查询时检索有关查询信息的正确方法是什么?

为什么不使用 doctrine 的默认更新而不是行 sql ?

$q = Doctrine_Query::create()
        ->update('MdwReportesOperacion')
        ->set('mmaplicado', '2.742495126705653')
        ->where('id = ?', array(5294));
$rows = $q->execute();
echo $rows;

编辑:

我不知道如何从原始原则查询中检索结果,但您仍然可以使用 pdo 查询:

// update the way you want to retrieve database information
$database = sfYaml::load(dirname(__FILE__).'/../config/databases.yml');
$param = $database['all']['doctrine']['param'];
$conn = new PDO($param['dsn'], $param['username'], $param['password']);
// and then perform the query and retrieve the result
$rows = $conn->exec("UPDATE mdw_reportes_operacion SET mmaplicado = 2.742495126705653 WHERE id = 5294;");
echo $rows;