2017-04-17 12 views
1

トリガ機能を作成しました。私はテーブルに行を挿入します。私はエラーが発生します。 Geom、k1k、k20k、pro_clustur_idはデフォルトで空です。行が挿入されると、トリガーが起動されます。どうすればこの問題を解決できますか?Postgresqlトリガ実行エラー

Failed to execute SQL. Error: ERROR: function st_point(double precision, double precision) does not exist LINE 1: ...denem_project set geom = st_transform(st_setsrid(st_point(p...^HINT: No function matches the given name and argument types. You might need to add explicit type casts. QUERY: update denem.denem_project set geom = st_transform(st_setsrid(st_point(project_lng, project_lat), 4326), 500000) where id is not null and pro_cluster_id is null and project_lng is not null and project_lat is not null CONTEXT: PL/pgSQL function create_cluster_id() line 4 at SQL statement

CREATE OR REPLACE FUNCTION denem.create_cluster_id() 
    RETURNS trigger AS $$ 
BEGIN 
    IF TG_OP = 'INSERT' THEN 
     update denem.denem_project set geom = st_transform(st_setsrid(st_point(project_lng, project_lat), 4326), 500000) where id is not null and pro_cluster_id is null and project_lng is not null and project_lat is not null ; 
     update denem.denem_project t1 set k20k=t2.fish_id from spatial.fish_net_k20k t2 where id is not null and pro_cluster_id is null and st_intersects(t1.geom,t2.geom) and k20k is null ; 
     update denem.denem_project t1 set k1k=t2.fish_id from spatial.fish_net_k1k t2 where id is not null and pro_cluster_id is null and st_intersects(t1.geom,t2.geom) and k1k is null ; 
     update denem.denem_project set pro_cluster_id= (id||''||k20k)::bigint where id is not null and pro_cluster_id is null and k20k is not null; 
    END IF; 
    RETURN NEW; 
END; 
$$ language 'plpgsql'; 

CREATE TRIGGER create_cluster_id 
    AFTER INSERT 
    ON denem.denem_project 
    FOR EACH ROW 
    EXECUTE PROCEDURE denem.create_cluster_id(); 
+0

PostGISがインストールされていないか、またはschにインストールされていますemaはデータベースユーザの 'search_path'にありません。 –

+0

Postgisがインストールされています – Fatih

答えて

0

まず、スキーマのPostGISがインストールされている見つけます。

あなたはスキーマ名がわかれば、とトリガ関数を作成

SELECT n.nspname 
FROM pg_extension x 
    JOIN pg_namespace n 
     ON x.extnamespace = n.oid 
WHERE x.extname = 'postgis'; 

\dx postgis 

またはSQLクエリにpsqlでこれを行うことができますいずれか

CREATE FUNCTION ... RETURNS trigger SET search_path='schemaname' AS ...;

関連する問題