php - Doctrine 1.2 自动加入 i18n?

标签 php oop orm internationalization doctrine


我想扩展 i18n 行为,以便它在任何类型的查询(DQL、关系、getTable)上自动加入转换表。
另外它需要定义默认语言参数,所以当我在没有设置语言的情况下进行查询时,它会回退到默认语言。
注意:我正在寻找通用行为,因此它适用于所有 i18n 模型对象,而不是为每个类编写和覆盖。

举个例子:
product -> id, category_id, price...
product_translation -> id, lang, name, description...

使用当前的解决方案,当我这样做时:Doctrine_Core::getTable('Product')->findAll(),它在不加入翻译的情况下获取所有产品。
所以在 Controller 中,我必须遍历所有记录并重新应用翻译后的值,使用 $product->name = $product->Translation['en']->name

我想要这样的东西:

  • Doctrine_Core::getTable('Product')->findAll() 它应该获取 lang='en' 的连接值
  • Doctrine_Core::getTable('Product)->findAll('en')同上
  • 它也应该与关系一起工作,所以例如,如果我有一个类 User 有很多产品 $user->Products 它应该返回一个包含翻译的集合。
  • 还有像 $user->Products('en') 应该返回其他(非默认)语言的集合
  • 魔法函数也不错(如果可能的话)...像 Doctrine_Core::getTable('Product')->getByCategoryAndLang(1,'en')

有人可以帮忙吗?我正在查看模板和行为,我认为这是要走的路,但不知道如何实现这一点

编辑: 我发现大家对此兴趣不大,所以让我尝试一个更简单的问题。您通常如何通过关系获取 i18n 字段。例如,我如何调用 $user->Products 并获取带有加载翻译的产品?

最佳答案

我认为你不需要扩展标准的 Doctrine 行为,除非你想要它是全自动的。但是你仍然可以像我们一样尝试这样做——我们使用一个 DAO(数据访问对象)返回给我们具体的 Doctrine 实体(Doctrine 表表示):

\DAO::get('Some\Namespace\Classname')

哪里Classname代表 PHP 类模型描述的表。我们的 DAO 类创建了 Classname 的实例封装到 proxy 中(请参阅设计模式)。

除了表类模型之外,我们为该表创建另一个类,它位于表模型之上并使用该模型进行操作。在这个类中,我们编写类似 getProducts($args) 的方法。 , getProduct($id) , getProductsByCategory($catId)

我认为这就是您要找的...

在方法中getProducts($args)然后你可以实现 ->leftJoin()在 DQL 中,将通过给定 $lang 加入翻译表$args 中的标识符范围。简单示例(未测试):

class Products extends \DAO {
    public function save($item) {
        $item->save();
    }

    public function getProducts($args = array()) {
        $order = array('p.id');

        $result = \Doctrine_Query::create()
            ->from('Some\Namespace\Product p')
            ->where('1 = 1');

        if(!empty($args['lang'])) {
            $result = $result->leftJoin('Some\Namespace\ProductTranslation pt ON pt.product_id = p.id AND pt.language = ?', $args['lang']);
        }

        $result = $result->orderBy($order);

        $result = $result->execute();

        return $result;
    }
}

然后调用

$products = DAO::get('Some\Namespace\Product')->getProducts(array('lang' => 1));

您获得所有加载了英文翻译的产品...

它不是那么自动化,你必须为每个模型编写你自己的 DAO 类,但这是一个很好的方法,因为你有 MVC/MVP 对象所需的不同数据定义类(模型)和数据操作类( Controller )面向应用架构...

关于php - Doctrine 1.2 自动加入 i18n?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5435834/

相关文章:

php - 如何创建一个 Doctrine 实体的模拟对象?

php - 为 Cassandra 安装 PHP 驱动程序

javascript - 为游戏建模 oop 层次结构

c# - NHibernate 缓存问题

java - JPA : one table with primary key and another table with primary and foreign key

PHP,获取 $_GET 以忽略来自 url 的数字

javascript - YII 应用程序中已弃用的 JQuery 方法 (yii 1.1.4)

带有 jQ​​uery 的 JavaScript OOP

oop - 命令模式-为什么封装在对象中?

django - "SELECT field as x..."与 Django ORM