I have to make requests with YEAR and I installed beberlei/DoctrineExtensions with doctrine command. I added the requested annotations
doctrine:
orm:
auto_generate_proxy_classes: '%kernel.debug%'
naming_strategy: doctrine.orm.naming_strategy.underscore
auto_mapping: true
dql:
datetime_functions:
year: DoctrineExtensions\Query\Mysql\Year
, but it does not work, I have this error:
Attempted to load class "Year" from namespace
"DoctrineExtensions\Query\Mysql". Did you forget a "use" statement for
another namespace?
The request:
public function groupTypeInterArray(){
$qb = $this->createQueryBuilder('i')
->select('YEAR(i.interventionDate)');
return $qb->getQuery()->execute();
}
Config Doctrine
# Doctrine Configuration
doctrine:
dbal:
driver: pdo_mysql
host: '%database_host%'
port: '%database_port%'
dbname: '%database_name%'
user: '%database_user%'
password: '%database_password%'
charset: UTF8
# if using pdo_sqlite as your database driver:
# 1. add the path in parameters.yml
# e.g. database_path: '%kernel.project_dir%/var/data/data.sqlite'
# 2. Uncomment database_path in parameters.yml.dist
# 3. Uncomment next line:
#path: '%database_path%'
orm:
auto_generate_proxy_classes: '%kernel.debug%'
naming_strategy: doctrine.orm.naming_strategy.underscore
auto_mapping: true
dql:
datetime_functions:
Year: DoctrineExtensions\Query\Mysql\Year
I searched all the afternoon, but I didn't find the solution.
Thank you in advance.
enter image description here
1.dql:
datetime_functions:
year: DoctrineExtensions\Query\Mysql\Year ???
2.dql:
datetime_functions:
Year: DoctrineExtensions\Query\Mysql\Year ???
Maybe
dql:
datetime_functions:
YEAR: DoctrineExtensions\Query\Mysql\Year
MONTH: DoctrineExtensions\Query\Mysql\Month
DAY: DoctrineExtensions\Query\Mysql\Day
For me removing the vendor dir and do a fresh composer install solved the problem.
in the query replace "Year" with "year"
so use the following code instead:
public function groupTypeInterArray(){
$qb = $this->createQueryBuilder('i')
->select('year(i.interventionDate)');
return $qb->getQuery()->execute();
}
and you also need to change the corresponding line in the doctrine config :
replaces this code
Year: DoctrineExtensions\Query\Mysql\Year
By this code
year: DoctrineExtensions\Query\Mysql\Year
PS : to know which link you have to use to add a function correctly in doctrine config you have to go on this link
Related
i have an issue with doctrine and symfony4.1, he don't take my charset parameter.
I have always my tables with charset utf8 and collate utf8_unicode_ci.
I have tried with mariadb / mysql and nothing work he never detect my charset configuration.
I have drop my database, recreate and migrate mutiple times and clear cache everytime. But he doesn't work.
commands :
php bin/console doctrine:database:drop --force
php bin/console doctrine:database:create
php bin/console make:migration
php bin/console doctrine:migration:migrate
here my configuration file :
doctrine:
dbal:
driver: pdo_mysql
host: "%env(DATABASE_MASTER_HOST)%"
dbname: "%env(DATABASE_DBNAME)%"
user: "%env(DATABASE_USER)%"
password: "%env(DATABASE_PASSWORD)%"
slaves:
slave1:
host: "%env(DATABASE_SLAVE_HOST)%"
dbname: "%env(DATABASE_DBNAME)%"
user: "%env(DATABASE_USER)%"
password: "%env(DATABASE_PASSWORD)%"
charset: utf8mb4
default_table_options:
charset: utf8mb4
collate: utf8mb4_unicode_ci
orm:
auto_generate_proxy_classes: '%kernel.debug%'
naming_strategy: doctrine.orm.naming_strategy.underscore
auto_mapping: true
mappings:
App:
is_bundle: false
type: annotation
dir: '%kernel.project_dir%/src/Entity'
prefix: 'App\Entity'
alias: App
dql:
string_functions:
GROUP_CONCAT: DoctrineExtensions\Query\Mysql\GroupConcat
IF: DoctrineExtensions\Query\Mysql\IfElse
FIND_IN_SET: App\DQL\FindInSet
When i add to my sql configuration file :
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
My database is created with utf8mb4_unicode_ci
but my tables is always generate with utf8 / utf8_unicode_ci
It work if i create my entity with the options parameter:
#ORM\Table(options={"charset":"utf8mb4"}...)
But i don't want to change all my table like that and my jointable are always with utf8.
why he don't take my configuration of charset.
It look likes something doens't work when i use MasterSlaveConnection.
Thanks a lot for your help.
I'm trying to make match against doctrine extension work but i get error with doctrine configuration file. I got Unrecognized option "dql" under "doctrine.orm" . How to propely use symfony 4 + doctrine + match against extension?
Match against file + conf https://gist.github.com/ZeBigDuck/1234419#file-addfulltextindexescommand-php
parameters:
# Adds a fallback DATABASE_URL if the env var is not set.
# This allows you to run cache:warmup even if your
# environment variables are not available yet.
# You should not need to change this value.
env(DATABASE_URL): ''
doctrine:
dbal:
# configure these for your database server
driver: 'pdo_mysql'
server_version: '5.7'
charset: utf8mb4
default_table_options:
charset: utf8mb4
collate: utf8mb4_unicode_ci
url: '%env(resolve:DATABASE_URL)%'
orm:
dql:
auto_generate_proxy_classes: '%kernel.debug%'
naming_strategy: doctrine.orm.naming_strategy.underscore
auto_mapping: true
# string_functions:
# MATCH_AGAINST: App\Extension\Doctrine\MatchAgainst
mappings:
App:
is_bundle: false
type: annotation
dir: '%kernel.project_dir%/src/Entity'
prefix: 'App\Entity'
alias: App
entity_managers:
default:
dql:
string_functions:
MATCH_AGAINST: App\Extension\Doctrine\MatchAgainst
Try it like this:
orm:
auto_generate_proxy_classes: '%kernel.debug%'
naming_strategy: doctrine.orm.naming_strategy.underscore
auto_mapping: true
dql:
string_functions:
MATCH_AGAINST: App\Extension\Doctrine\MatchAgainst
EDIT.. It should be something like this (not tested):
doctrine:
dbal:
# configure these for your database server
driver: 'pdo_mysql'
server_version: '5.7'
charset: utf8mb4
default_table_options:
charset: utf8mb4
collate: utf8mb4_unicode_ci
url: '%env(resolve:DATABASE_URL)%'
orm:
auto_generate_proxy_classes: '%kernel.debug%'
naming_strategy: doctrine.orm.naming_strategy.underscore
auto_mapping: true
dql:
string_functions:
MATCH_AGAINST: App\Extension\Doctrine\MatchAgainst
mappings:
App:
is_bundle: false
type: annotation
dir: '%kernel.project_dir%/src/Entity'
prefix: 'App\Entity'
alias: App
I tried to follow the tutorial installation for SonataBundle tutorial
I change only mapping in this way
doctrine:
dbal:
driver: pdo_mysql
host: '%database_host%'
port: '%database_port%'
dbname: '%database_name%'
user: '%database_user%'
password: '%database_password%'
charset: UTF8
# if using pdo_sqlite as your database driver:
# 1. add the path in parameters.yml
# e.g. database_path: '%kernel.project_dir%/var/data/data.sqlite'
# 2. Uncomment database_path in parameters.yml.dist
# 3. Uncomment next line:
#path: '%database_path%'
types:
json: Sonata\Doctrine\Types\JsonType
orm:
auto_generate_proxy_classes: "%kernel.debug%"
naming_strategy: doctrine.orm.naming_strategy.underscore
auto_mapping: true
mappings:
ApplicationSonataMediaBundle: ~
SonataMediaBundle: ~
the command
php app/console sonata:easy-extends:generate --dest=src SonataMediaBundle
generate in src/Application/Sonata/MediaBundle/ApplicationSonataMediaBundle
but always I get this error :
Class 'Application\Sonata\MediaBundle\ApplicationSonataMediaBundle' not found
Search in latest Sylius-standard does not work:
[Syntax Error] line 0, col 92: Error: Expected known function, got 'MATCH'
[1/2] QueryException: select u.itemId, u.tags, u.entity from Sylius\Bundle\SearchBundle\Model\SearchIndex u WHERE MATCH(u.value) AGAINST (:searchTerm) > 0
How to fix?
You need to add the custom function to you doctrine config as in the Sylius app/config/config.yml
doctrine:
...
orm:
dql:
string_functions:
MATCH: Sylius\Bundle\SearchBundle\Extension\Doctrine\MatchAgainstFunction
Here are the steps to get it working :
In app/config/config.yml put in the following lines
doctrine:
dbal:
driver: %sylius.database.driver%
host: %sylius.database.host%
port: %sylius.database.port%
dbname: %sylius.database.name%
user: %sylius.database.user%
password: %sylius.database.password%
charset: UTF8
orm:
auto_generate_proxy_classes: %kernel.debug%
entity_managers:
default:
auto_mapping: true
mappings:
gedmo_loggable:
type: annotation
prefix: Gedmo\Loggable\Entity
dir: "%kernel.root_dir%/../vendor/gedmo/doctrine-extensions/lib/Gedmo/Loggable/Entity"
is_bundle: false
filters:
softdeleteable:
class: Gedmo\SoftDeleteable\Filter\SoftDeleteableFilter
enabled: true
dql:
string_functions:
MATCH: Sylius\Bundle\SearchBundle\Extension\Doctrine\MatchAgainstFunction
In your mysql database look for the table sylius_search_index and check if it has a full index on the value column, if not just run the below command :
ALTER TABLE sylius_search_index ADD FULLTEXT index_name(
value
)
On the console run the following command for your products:
php app/console sylius:search:index
The above command builds a list of search terms for the search in the sylius_search_index table value column.
That should be all !
My specific question: How can I troubleshoot a failure to create a database
using a Symfony2 parameters.ini file?
This has to do with Windows7 and Symfony2. I am trying to create a database
after configuring Symfony2, and I fail. (Details: I am working on Windows 7
64 bit, xampp 1.7.7 with PHP 5.3.8 and Symfony2 2.0.14).
When I try this from a command line:
php app/console doctrine:database:create
I get this:
Could not create database for connection named <comment>jobeet</comment>
SQLSTATE[28000] [1045] Access denied for user 'root'#'localhost' (using password: YES)
My parameters.ini file looks like this:
[parameters]
database_driver="pdo_mysql"
database_host="localhost"
database_port="3306"
database_name="jobeet"
database_user="root"
database_password="[intentionally left blank]"
mailer_transport="smtp"
mailer_host="localhost"
mailer_user=""
mailer_password=""
locale="en"
secret="[intentionally left blank]"
I can start MySql from the command line (mysqld --console), and get to MySql
as a root user (mysql -p[intentionally left blank] -u root) and create a
database (CREATE DATABASE test;), so I think my server is running and I can
use it.
I suspect the problem with "Access denied for user 'root'#'localhost'" has to
do with it not having the password for MySql root.
If anyone has ever run into this before, and knows what to do, your help
would be much appreciated.
I attempted to GRANT ALL PRIVILEGES with the following:
mysql> grant all privileges on *.* to 'root'#'localhost';
Query OK, 0 rows affected (0.05 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
I'm worried that is says '0 rows affected'. That can't be good.
Here is my config.yml. Plz let me know if you see problems.
imports:
- { resource: parameters.ini }
- { resource: security.yml }
framework:
#esi: ~
#translator: { fallback: %locale% }
secret: %secret%
charset: UTF-8
router: { resource: "%kernel.root_dir%/config/routing.yml" }
form: true
csrf_protection: true
validation: { enable_annotations: true }
templating: { engines: ['twig'] } #assets_version: SomeVersionScheme
session:
default_locale: %locale%
auto_start: true
# Twig Configuration
twig:
debug: %kernel.debug%
strict_variables: %kernel.debug%
# Assetic Configuration
assetic:
debug: %kernel.debug%
use_controller: false
# java: /usr/bin/java
filters:
cssrewrite: ~
# closure:
# jar: %kernel.root_dir%/java/compiler.jar
# yui_css:
# jar: %kernel.root_dir%/java/yuicompressor-2.4.2.jar
# Doctrine Configuration
doctrine:
dbal:
driver: %database_driver%
host: %database_host%
port: %database_port%
dbname: %database_name%
user: %database_user%
password: %database_password%
charset: UTF8
orm:
auto_generate_proxy_classes: %kernel.debug%
auto_mapping: true
# Swiftmailer Configuration
swiftmailer:
transport: %mailer_transport%
host: %mailer_host%
username: %mailer_user%
password: %mailer_password%
jms_security_extra:
secure_controllers: true
secure_all_services: false
You created a database named test, not jobeet.