首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在LiipFunctionalTest包中使用年份、月、日mysql函数时出错

在LiipFunctionalTest包中使用年份、月、日mysql函数时出错
EN

Stack Overflow用户
提问于 2015-03-04 14:18:45
回答 1查看 1.2K关注 0票数 2

我正在使用DAYMONTHYEAR mysql的函数(year)和LiipFunctionalTestBundle。当我做测试的时候:

SQLSTATE[HY000]: General error: 1 no such function: YEAR

最后,测试失败了。我想是因为这个。

这是我的config_test文件:

代码语言:javascript
复制
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           

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

代码语言:javascript
复制
$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"));

如果我运行这个应用程序,我就没有问题了。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-03-07 14:55:48

这个问题不是与mysql有关,而是与sqlite有关。我使用sqlite运行测试,这会引发上述异常。我发现解决这个问题的最简单的方法是用两个数据库都能理解的通用版本更改查询。

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

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28856766

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档