MySQL is 5.7.23.
IFNULL(INET_ATON(\'\'),0)
returns a 0 in a plain select, but ERRORS during update ... set
assignment
Q: Is there a
In fact, the empty string is an invalid argument in both cases. You can see that it's a warning if you view the warnings:
mysql> warnings;
Show warnings enabled.
mysql> select IFNULL(inet_aton(''),0);
+-------------------------+
| IFNULL(inet_aton(''),0) |
+-------------------------+
| 0 |
+-------------------------+
1 row in set, 1 warning (0.00 sec)
Warning (Code 1411): Incorrect string value: '''' for function inet_aton
I'm not sure why this is only a warning when using SELECT but an error when using the same function in UPDATE.
A workaround is to use NULL instead of a blank string. INET_ATON() returns NULL without a warning or error if you pass NULL as your IP address string:
mysql> update foo set ip = ifnull(inet_aton(''), 0) where id=0;
ERROR 1411 (HY000): Incorrect string value: '''' for function inet_aton
mysql> update foo set ip = ifnull(inet_aton(null), 0) where id=0;
Query OK, 1 row affected (0.01 sec)
Rows matched: 1 Changed: 1 Warnings: 0
I understand you said it's hard to change the app, but this is the only workaround I can suggestion.
The best solution of course is to avoid passing any invalid string to INET_ATON().