settings
テーブルのモデルを作成するためにdoctrine 2.1を使用しています:
id | arg | value | category
1 | name | foo | general_settings
2 | desc | bar | general_settings
さまざまなカテゴリに多くの設定があるとします。特定のカテゴリのすべての設定を取得するには、次のようにします。
$q = Doctrine_Query::create()
->from('Setting p')
->where('p.category = ?', $category_name);
この時点ですべてが正常に動作します。ええと.. 64,000ドルの問題は、次のように結果を読み取ることができるデータアクセスの代替手段が存在するかどうかです。
$resultSet = $q->execute();
//the magic here could be use the -arg- column as index
$requested_setting = $resulSet['name']
//print the setting value
echo $requested_setting['value']; //should prints "foo"
//another way
echo $resulSet['desc']['value']; //should prints "bar"
わかった:ここでのトリックはINDEX BY
語。
queryクラスをインポートします(常にオプションではありません)。
use \Doctrine\ORM\Query;
クエリを作成します。
$query = $this->data->em->createQuery('
SELECT s
FROM models\Setting s
INDEX BY s.arg //to set array custom key
WHERE s.category = :category');
$query->setParameter('category', 'general');
読み取り専用配列で機能するように非表示モードを設定します
$settings = $query->getResult(Query::HYDRATE_ARRAY);
値を表示します。
echo $settings['desc']['value']; // prints "bar"
QueryBuilder
オブジェクトを使用すると、from
ステートメントでインデックスを設定できます。
$qb = $em->createQueryBuilder();
$qb->select('s');
$qb->from('models\Settings', 's', 's.arg'); // here the magic
$result = $qb->getQuery()->getResult();
その後、次のようにオブジェクトにアクセスできます。
$description = $result['desc'];
$value = $description->getValue();
EntityRepositoryでcreateQueryBuilderを使用する場合、参考までに、エイリアスとともにINDEX BYを直接指定できます。
$this->createQueryBuilder('p', 'p.id')
これにより、EntityRepositoriesで自動的に処理されるfromを手動で処理する必要がなくなります。
DoctrineのIndexBy関数を使用して、列の値を配列のインデックスとして表示します
$this
// database table alias
->createQueryBuilder( 'app_settings' )
// first parameter should be alias and second parameter will be column name, which you want to show as array index
->indexBy('app_settings','app_settings.name')
// get query
->getQuery()
// get doctrine result in array format
->getArrayResult();
上記のクエリの結果は次の形式になります。 上記のクエリの結果