Carlos Eduardo Sotelo Pinto escribió: > DECLARE > arr varchar[]; > BEGIN > arr := regexp_split_to_array(_imeis, E'\\s+'); > FOR i IN 1..array_length(arr, 1) LOOP > RETURN QUERY
Creo que deberías hacer una única consulta con todos los elementos del array, en lugar de una consulta para cada elemento. Es decir, elimina el LOOP y el LIMIT 1, y tu WHERE debería ser algo como ... > FROM gpstracking_device_tracks > WHERE gpstracking_device_tracks.imei = arr[i]::VARCHAR WHERE gpstracking_device_tracks.imei = ANY (arr) AND ... Vas a tener que solucionar de otra forma el que te retorne sólo una fila para cada imei, claro. -- Álvaro Herrera http://www.2ndQuadrant.com/ PostgreSQL Development, 24x7 Support, Training & Services - Enviado a la lista de correo pgsql-es-ayuda ([email protected]) Para cambiar tu suscripción: http://www.postgresql.org/mailpref/pgsql-es-ayuda
