Sujet : Re: It's possible get sql error code using TDBC ?
De : wortkarg3 (at) *nospam* yahoo.com (Harald Oehlmann)
Groupes : comp.lang.tclDate : 29. Mar 2025, 11:13:30
Autres entêtes
Organisation : A noiseless patient Spider
Message-ID : <vs8h4a$12m92$1@dont-email.me>
References : 1 2 3
User-Agent : Mozilla Thunderbird
Am 29.03.2025 um 02:52 schrieb Luis Alejandro Muzzachiodi:
El 28/03/2025 a las 10:55, Harald Oehlmann escribió:
Am 28.03.2025 um 03:02 schrieb Luis Alejandro Muzzachiodi:
Hello,
>
I am using the TDBC mysql driver. Maybe I'm not getting it but I can't find how to retrieve the sql error message that a transaction returns. That is, if I capture (for example, with catch) the error shows me all a lot of data that, for practical purposes, it is too much information and in English, of curse. Can the SQL code from the error be recovered?. In this way, it could show a simpler message and in Spanish.
>
Example:
>
instead of show this ...
Cannot delete or update a parent row: a foreign key constraint fails (`xxxx_DB01`.`xxx`, CONSTRAINT `RI_xxid` FOREIGN KEY (`xxid`) REFERENCES `xx_xxx` (`xxid`) ON UPDATE CASCADE)
>
because i received the error number 1451, i would show :
"No se puede borrar este blabla porque tiene bleble asociados"
>
Thanks,
>
Alejandro
>
Alejandro,
I have no answer, sorry. The funny thing is, that TDBC defines the error codes for all rivers, but only the ODBC driver follows it.
But that is easy, as the TDBC error reporting is defined as to be the same for all platforms.
>
At the end, I have a big driver-dependent if to catch some errors, I am intersted in (like "record exists" on insert).
>
Sorry for the non-related noise.
>
Consider to register a ticket in tdbc::mysql fossil. Massimo has eventually more insights...
>
Harald
Hello Harald,
i've created a ticket.
I hope it can be implemented, if I can help, I will be happy to.
Saludos,
Alejandro
Great !
https://core.tcl-lang.org/tdbcmysql/info/3eaf36b1491ec71dWizard Christian Werner already answered and gave an idea.
Take care,
Harald