Doctrine automatically creates table names from the record class names. For this reason, it is recommended to name your record classes using the following rules:
Use CamelCase naming
Underscores are allowed
The first letter must be capitalized
The class name cannot be one of the following (these keywords are reserved in DQL API):
SELECT, FROM, WHERE, UPDATE, DELETE, JOIN, OUTER, INNER, LEFT, GROUP, ORDER, BY, HAVING,
FETCH, DISTINCT, OBJECT, NULL, TRUE, FALSE,
NOT, AND, OR, BETWEEN, LIKE, IN,
AS, UNKNOWN, EMPTY, MEMBER, OF, IS, ASC, DESC,
AVG, MAX, MIN, SUM, COUNT,
MOD, UPPER, LOWER, TRIM, POSITION,
CHARACTER_LENGTH, CHAR_LENGTH, BIT_LENGTH, CURRENT_TIME, CURRENT_DATE,
CURRENT_TIMESTAMP, NEW, EXISTS, ALL, ANY, SOME.
Example. My_PerfectClass
If you need to use a different naming schema, you can override this using the setTableName() method in the setTableDefinition() method.