Insertando correctamente literales en consultas dinámicas PL / PgSQL EXECUTE

Lo siguiente es parte de una función plpgsql. El problema es que el resultado desource_geom ytarget_geom es uncharacter varying tipo de datos, y por lo tanto tengo que rodear los dossource_geom ytarget_geom en comillas (''). La cosa es que en el lenguaje plpgsql no sé cómo puedo hacerlo.
Esto es lo que tengo en este momento:

 EXECUTE 'update ' || quote_ident(geom_table) || 
        ' SET source = ' || source_geom || 
        ', target = ' || target_geom ||
        ' WHERE ' || quote_ident(gid_cname) || ' =  ' || _r.id;

El error que estoy teniendo es el siguiente;

ERROR:  syntax error at or near "C03B9E3B66052D400DDEFC2BD0F24140"
LINE 1: ...pdate track_points SET source = 0101000020E6100000C03B9E3B66...
                                                             ^
QUERY:  update track_points SET source = 0101000020E6100000C03B9E3B66052D400DDEFC2BD0F24140, target = 0101000020E610000075690DEF83052D40F88E75CCD4F24140 WHERE ogc_fid =  2
CONTEXT:  PL/pgSQL function "create_network" line 26 at EXECUTE statement

Por favor, cualquier sugerencia de cómo puedo resolver este problema.

Respuestas a la pregunta(2)

Su respuesta a la pregunta