我正在使用 DAY
、MONTH
、YEAR
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/