MasterSlaveFeature How-To

В настоящее время мои Db-модели используют AbstractTableGateway, и все мои запросы select / insert / update / delete работают просто отлично. Но теперь я хотел бы добавить MasterSlaveFeature и яЯ немного запутался, как это сделать. Документация неТ точно привести хороший пример:

http://zf2.readthedocs.org/en/latest/modules/zend.db.table-gateway.html#tablegateway-features

В настоящее время у меня есть эта настройка:}

namespace Login\Model;

use Zend\Db\TableGateway\Feature\MasterSlaveFeature;
use Zend\Db\TableGateway\Feature\FeatureSet;
use Zend\Db\TableGateway\AbstractTableGateway;
use Zend\Db\Sql\Select;
use Zend\Db\Sql\Expression;

class Passport extends AbstractTableGateway
{
public function __construct($adapter, $slave)
{
    $this->table = 'passport';

    $this->adapter = $adapter;

    $this->featureSet = new FeatureSet();
    $this->featureSet->addFeature(new MasterSlaveFeature($slave));

    $this->initialize();
}

public function Profile($employeeid)
{
    $result = $this->select(function (Select $select) use ($employeeid) {
        $select
            ->columns(array(
                'count' => new Expression('COUNT(*)'),
                'employeeid',
                'passwd',
                'group',
                'name',
                'status',
                'timezone',
                'timeformat',
                'locale',
                'max_search'
            ))
            ->where($this->adapter->getPlatform()->quoteIdentifier('employeeid') . ' = ' . $this->adapter->getPlatform()->quoteValue($employeeid))
            ->limit(1);
    });

    return $result->current();
}

Я передаю два адаптера $ adapter и $ slave, у каждой из которых есть одинаковые таблицы, за исключением того, что один пустой, а другой фактически содержит данные. На основании документации, что у меня должно работать, но я чувствую, что что-то здесь упускаю, но нене знаю что.

$ Adapter - это база данных master, в которой есть данные. $ Slave - это база данных slave, в которой нет данных.

Я хотел бы, чтобы мой SELECTS взял данные от $ slave (который в настоящее время не имеет данных), а Insert / Update / Delete должен перейти к $ адаптеру.

Может ли кто-нибудь помочь мне понять это? Спасибо

Ответы на вопрос(1)

Ваш ответ на вопрос