Here is my code on that I have dynamic column name while I joined to other tables data type mismatch will occur. How can I resolve this issue..
CREATE OR REPLACE FUNCTION migratePartnerAdvertiser() RETURNS int4 AS '
DECLARE r RECORD;
BEGIN
FOR r IN
select distinct COLUMN_NAME from INFORMATION_SCHEMA.COLUMNS
where TABLE_NAME = ''casesheetcomplaints'' and table_schema=''public''
LOOP
EXECUTE concat(''INSERT INTO patient_form_value(patient_form_id,
form_template_field_id, field_value)
select pf.id AS patient_form_id, ftf.id AS form_template_field_id, c.'',
r.column_name, '' AS field_value
FROM casesheetcomplaints c
LEFT OUTER JOIN form_field ff ON ff.field_name = '',r.column_name,''
LEFT OUTER JOIN form_template_field ftf ON ftf.form_field_id = ff.id
LEFT OUTER JOIN patient_form pf on c.patient_id = pf.patient_id
AND pf.created_date = c.reg_date
where c.'', r.column_name, '' IS NOT NULL AND ftf.id IS NOT NULL
GROUP BY c.patient_id, c.'', r.column_name, '', pf.id, ftf.id'');
END LOOP;
return 1;
END;
' LANGUAGE plpgsql;
Error message:
ERROR: operator does not exist: character varying = numeric LINE 4: LEFT OUTER JOIN form_field ff ON ff.field_name = weight ^ HINT: No operator matches the given name and argument type(s). You might need to add explicit type casts. QUERY: INSERT INTO patient_form_value(patient_form_id, form_template_field_id, field_value) select pf.id AS patient_form_id, ftf.id AS form_template_field_id, c.weight AS field_value FROM casesheetcomplaints c LEFT OUTER JOIN form_field ff ON ff.field_name = weight LEFT OUTER JOIN form_template_field ftf ON ftf.form_field_id = ff.id LEFT OUTER JOIN patient_form pf on c.patient_id = pf.patient_id AND pf.created_date = c.reg_date where c.weight IS NOT NULL AND ftf.id IS NOT NULL GROUP BY c.patient_id, c.weight,pf.id,ftf.id