Detta borde fungera för dig
SET NEW.a = DEFAULT(NEW.a)
EDIT:Det verkar som att det inte fungerar.
Använd den här lösningen
IF NEW.a = '' THEN
SELECT COLUMN_DEFAULT INTO @def
FROM information_schema.COLUMNS
WHERE
table_schema = 'database_name'
AND table_name = 'your_table'
AND column_name = 'a';
SET NEW.a = @def;
END IF;
Du kan också prova
SET NEW.a = DEFAULT(table_name.a)