mysql - 在 LiipFunctionalTest 包中使用 YEAR、MONTH、DAY mysql 函数时出错

标签 mysql unit-testing symfony doctrine-orm liipfunctionaltestbundle

我正在使用 DAYMONTHYEAR mysql 的函数 ( http://dev.mysql.com/doc/refman/5.5/en/date-and-time-functions.html#function_year ) 和 LiipFunctionalTestBundle。当我运行测试时,我得到:

SQLSTATE[HY000]:一般错误:1 没有这样的函数:YEAR

最终测试失败。我猜是因为这个。

这是我的config_test 文件:

imports:
    - { resource: config_dev.yml }

framework:
    test: ~
    session:
        storage_id: session.storage.filesystem
        name: MOCKSESSID

web_profiler:
    toolbar: false
    intercept_redirects: false

swiftmailer:
    disable_delivery: true

liip_functional_test: 
  cache_sqlite_db: true
  authentication:
    username: "root"
    password: "admin"

doctrine:
  dbal:
    default_connection: default
    connections:
      default:
        driver:   pdo_sqlite
        path:     %kernel.cache_dir%/test.db
  orm:
    dql: 
      datetime_functions:
        YEAR: DoctrineExtensions\Query\Mysql\Year
        MONTH: DoctrineExtensions\Query\Mysql\Month
        DAY: DoctrineExtensions\Query\Mysql\Day           

在我的代码中,我将它们用作:

$em = $this->getDoctrine()->getManager();
$emConfig = $em->getConfiguration();
$emConfig->addCustomDatetimeFunction('YEAR', 'DoctrineExtensions\Query\Mysql\Year');
$emConfig->addCustomDatetimeFunction('MONTH', 'DoctrineExtensions\Query\Mysql\Month');
$emConfig->addCustomDatetimeFunction('DAY', 'DoctrineExtensions\Query\Mysql\Day');

....
$em = $this->get('doctrine.orm.entity_manager');
$dql = $em->createQuery('SELECT um FROM Acme\AcmeBundle\Entity\Menu um WHERE 
                  um.user = :id and 
                  YEAR(um.day) = :year and 
                  MONTH(um.day) = :month and 
                  DAY(um.day) = :day');
      $dql->setParameter('id', $id);
      $dql->setParameter('year', $now->format("Y"));
      $dql->setParameter('month', $now->format("m"));
      $dql->setParameter('day', $now->format("d"));

如果我运行该应用程序,我不会遇到问题。

最佳答案

问题与mysql无关,而是与sqlite有关。我使用 sqlite 运行测试,它抛出了上面的异常。我发现解决该问题的最简单方法是使用两个数据库都能理解的通用版本更改查询。

我还认为每个查询都有两个版本,一个用于 mysql,一个用于 sqlite,并在应用程序执行测试时使用环境。例如,如果我使用 test 环境,则使用 sqlite 查询,否则使用 mysql。然而我认为这个选项非常依赖并且将来很难维持。

关于mysql - 在 LiipFunctionalTest 包中使用 YEAR、MONTH、DAY mysql 函数时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28856766/

相关文章:

node.js - 如何在不修改源代码的情况下获得 Mocha 测试的代码覆盖率?

security - Symfony2 安全.yml

objective-c - 如何使用 OCMock for iOS 模拟私有(private)属性?

java - Mockito 转换为泛型

doctrine-orm - Doctrine DBAL 查询生成器省略了一些连接

php - SonataUser - 从管理表单中删除字段

php - mysql 准备好的语句,既没有错误也没有数据库中的数据

mysql - Java 驱动程序和 Play 框架的神秘 MySQL 编码问题

php - 拉维尔 5.4 : Cannot retrieve data from a relationship

mysql - 哪个 MySQL 归类比较例如é 和 e 相等?