When I insert decimals into database I get the following error message:
ORA-01722: invalid number
Oracle wants decimals (e.g. NUMBER(5,2)) separated by comma instead of a dot. I think the reason is that I use the german version of Windows. I tried to modify the following method of \Doctrine\DBAL\Driver\OCI8\OCI8Statement::bindValue() just for testing of course:
With this modification I do not get the error anymore.
It would be great if a solution could be found. The strange thing is, if I query "SELECT * from nls_database_parameters where PARAMETER='NLS_NUMERIC_CHARACTERS'" I get ".," which means that a dot is already used as decimal separator. Maybe Oracle preferes the Locale of the OS?!
Maybe you could provide a setting which defines what separator should be used for decimals.
I found some Links that might be interesting regarding this issue:
- http://docs.oracle.com/cd/E19455-01/806-0169/overview-9/index.html (Oracle Docs - Decimal and Thousands Separators)
|Status||Open [ 1 ]||Resolved [ 5 ]|
|Fix Version/s||2.3 [ 10184 ]|
|Resolution||Fixed [ 1 ]|