0

DB に行を挿入しようとすると、致命的なエラーが発生します。何が起こっているのかわかりません。いくつかのブログを読みましたが、解決策はありません。私のコードは、Evan がブログで公開している例と同じです。

私のモデルクラス

class CommentTable 
{
    protected $_commentTableGateway;
    protected $_hydratator;
    protected $_resultSet;

    public function __construct($adapter)
    {
        $this->_hydratator           = new \Zend\Stdlib\Hydrator\ClassMethods;
        $rowObjectPrototype = new Comment();
        $this->_resultSet          = new \Zend\Db\ResultSet\HydratingResultSet($this->_hydratator, $rowObjectPrototype);
        $this->_commentTableGateway =  new TableGateway('comments', $adapter, null, $this->_resultSet );
    }   
    public function fetchAll() 
    {
        return $this->_commentTableGateway->select();
    }

    public function saveComment(Comment $comment)
    {  
        $id = (int)$comment->getId();
        if ($id == 0) {
           $this->_commentTableGateway->insert($this->_hydratator->extract($comment));//this fails
        } else {
            if ($this->getComment($id)) {
                $this->_commentTableGateway->update($data, array('id' => $id));
            } else {
                throw new \Exception('El comentario que queire editar no exite');
            }
        }
    }

    public function getComment($id)
    {
        $id  = (int) $id;
        $rowset = $this->_commentTableGateway->select(array('id' => $id));
        $row = $rowset->current();
        if (!$row) {
            throw new \Exception("Could not find row $id");
        }
        return $row;
    }
}
</code>
<code>

In module class:

//a factory in service manager
'Comment\Model\CommentTable' =>  function($sm) {
        $dbAdapter = $sm->get('Zend\Db\Adapter\Adapter');
        $table = new CommentTable($dbAdapter);
        return $table;
},
</code>    
<code>

My controller:

public function getCommentTable()
{
    if (!$this->_commentTable) {
        $sm = $this->getServiceLocator();
        $this->_commentTable = $sm->get('Comment\Model\CommentTable');
    }
    return $this->_commentTable;
}

</code>

そして、私はこのエラーを受け取ります:

キャッチ可能な致命的なエラー: クラス stdClass のオブジェクトを D:\xampp\htdocs\haystack\vendor\zendframework\zendframework\library\Zend\Db\Adapter\Driver\Pdo\Statement.php 行 258 の文字列に変換できませんでした

エラーの種類 (「stdClass を文字列に変換できませんでした」) はわかっていますが、何が起こっているのかわかりません...

どんな助けでも大歓迎です

敬具。

4

1 に答える 1

0

うまくいけば、これはあなたを助けるでしょう. これが私のTableGatewayです

class Domains extends AbstractTableGateway
{
    public function __construct($adapter)
    {
        $this->table = 'domains';

        $this->adapter = $adapter;

        $this->initialize();
    }
}

データを挿入する方法は次のとおりです。

$this->getTableDomains()->insert(array(
    'companyid' => $params['companyid'],
    'domain_id' => $result->id,
    'name'      => $name,
    'type'      => strtoupper($params['type']),
    'content'   => strtolower($params['content']),
    'ttl'       => $ttl,
    'prio'      => $prio
));
于 2013-01-29T17:03:58.043 に答える