[postgreSQL] [PostgreSQL] stored function(stored procedures) 사용하기

얼마 전에 stored function과 trigger를 첨으로 사용해보았다.
엄청 어려운 수준으로 사용은 안 해봤지만, 정리하면 누군가에게 도움이 될 수 있지 않을까.. 하는 마음에
(하루만 지나면 기억 못 하는 나 자신을 위해서...)
stored function, trigger에 대하여 각각 정리해보려고 한다.
 

참고 URL
http://www.postgresqltutorial.com/postgresql-stored-procedures
https://www.postgresql.org/docs/current/sql-createfunction.html

 

참고 사이트에서는 stored function의 장단점에 대하여 다음과 같이 기술하고 있다.

장점

- application과 database 서버 간의 통신을 줄일 수 있다.
  application에서 발생할 수 있는 여러 번의 SQL 호출을 stored function 호출 한 번으로 처리할 수 있다.
- application의 성능을 향상할 수 있다.
  stored function은 미리 컴파일된 상태로 database에서 동작하기 때문에 application의 부담을 줄일 수 있다.
- 재사용이 편리하다.
  stored function을 정의해두면, 어떤 application에서도 자유롭게 호출하여 사용할 수 있다.

단점

- 개발 속도가 느려질 수 있다.
  application 개발 스킬과 다른 스킬이 필요하기 때문에 개발 속도가 느려질 수 있다.
- 버전 관리 및 디버깅이 어렵다.
- MySQL, Microsoft SQL과 같은 다른 database 서버에서 동작하지 않을 수 있다.

stored function을 어떤 상황에서 사용할지는 각자 판단해야 할 것 같다.

참고 사이트에 stored function의 기초부터 잘 설명이 되어 있기 때문에

여기서는 2가지 상황을 가정하여 function을 구현하였다.
 

1. A table의 데이터를 읽어와서 B table에 insert

CREATE OR REPLACE FUNCTION insert_A_to_B(cond_id bigint)
returns int
AS $$
DECLARE
  result int := 0;
  data_info record;
  data_value boolean;
  now_date timestamp := now();
BEGIN
  for data_info IN select * from A where id > cond_id loop
    raise notice '%, %', data_info.id, data_info.value;

    if data_info.value = 'PASS' then
      data_value := true;
    else
      data_value := false;
    end if;

    insert into B
      (id, value, created, modified)
    values
      (data_info.id, data_value, now_date, now_date);

    result := result+1;
  end loop;
  return result;
END; $$
LANGUAGE 'plpgsql';

위 예제는 단순한 사용법을 구현한 것이기 때문에 복잡한 조건을 포함하지 않았다.

- function에서 사용할 변수는 DECLARE에서 정의를 해야 한다.
- select 구문의 결과를 사용하기 위해서 record type을 사용하였다.

반복문과 조건문은 기존 언어처럼 다양하게 제공되고 있다.

반복문 : WHILE LOOP, FOR LOOP...
조건문 : IF/ELSEIF/ELSE, CASE/WHEN/ELSE


해당 stored function은 아래와 같이 호출하여 사용할 수 있다.

select insert_A_to_B(100);


2. A table에 data insert (data는 object array로 입력, function 안에서 B table의 값을 참고하기)


object를 parameter로 넘기기 위하여 아래와 같이 사용자 type을 정의한다.

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

create type a_type as (priority bigint, value varchar(32));

stored function은 다음과 같이 정의한다.

CREATE OR REPLACE FUNCTION insert_A_list(a_type[])
returns int
AS $$
DECLARE
  result int := 0;
  a_object a_type;
  now_date timestamp := now();
BEGIN
  foreach a_object IN array $1 loop
    if exists(select 1 from B where value=a_object.value) then
    
      insert into A
        (priority, value, created, modified)
      values
        (a_object.priority, a_object.value, now_date, now_date);

      result := result+1;
    end if;
  end loop;

  return result;
END; $$
LANGUAGE 'plpgsql';

parameter로 정의 부분에 parameter의 이름은 정의하지 않고
loop 구문에서 90694로 해당 parameter를 사용하였다.
(나 같이 이름 정하는 게 너무 어려운 사람들에게 좋은 방식이다.)

- foreach 구문을 사용하여 parameter로 넘어온 array를 처리하였다.
- exists 구문을 사용하여 table B의 값을 체크하였다.

위의 function은 아래와 같은 형태로 호출할 수 있다.

select insert_keyword_list(ARRAY[(1, 'test1'), (2, 'test2'), (3, 'test3')]::a_type[]);


호출할 때 ARRAY [.......]::a_type []과 같은 형식을 사용하기 싫다면
아래와 같이 variadic을 사용하여 parameter 정의하면

CREATE OR REPLACE FUNCTION insert_A_list(variadic a_type[])


아래와 같은 형식으로 function을 호출할 수 있다.

select insert_keyword_list((1, 'test1'), (2, 'test2'), (3, 'test3'));

 

variadic 사용에 주의할 점이 있다면, parameter가 100개가 넘어가면 에러가 발생하게 된다.

[출처] https://sungtae-kim.tistory.com/40

 

 

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
공지 오라클 기본 샘플 데이터베이스 졸리운_곰 2014.01.02 25085
공지 [SQL컨셉] 서적 "SQL컨셉"의 샘플 데이타 베이스 SAMPLE DATABASE of ORACLE 가을의 곰을... 2013.02.10 24564
공지 [G_SQL] Sample Database 가을의 곰을... 2012.05.20 25943
1025 [postgreSQL] PostgreSQL 계층형 쿼리 구현 방법 졸리운_곰 2023.01.29 35
1024 [postgreSQL] ORACLE쿼리에서 postgreSQL쿼리 변환 졸리운_곰 2023.01.29 26
» [postgreSQL] [PostgreSQL] stored function(stored procedures) 사용하기 졸리운_곰 2023.01.23 30
1022 [SQL] CRUD 기본 사용법 file 졸리운_곰 2023.01.23 30
1021 [postgreSQL] [Docker] Docker에 PostgreSQL 설치하기 file 졸리운_곰 2023.01.21 25
1020 [MYSQL] 테이블 스키마 설계 고려사항 졸리운_곰 2022.12.03 33
1019 [MySQL] "아는 만큼 빨라진다" 마이SQL 성능 튜닝 팁 10가지 file 졸리운_곰 2022.11.29 30
1018 [오라클] 오라클 연동 오류 [ORA-01017: invalid username/password; logon denied] 졸리운_곰 2022.11.28 76
1017 [오라클] 제약조건 확인 (FK 찾기) 졸리운_곰 2022.11.28 68
1016 [ADsP] 취업 깡패 ADP 뿌시기! "빅데이터 분석가 최고의 자격증이에요" file 졸리운_곰 2022.11.20 22
1015 [기계학습] [번역] TensorFlow Lite 튜토리얼 3 부 : Raspberry Pi의 음성 인식 졸리운_곰 2022.11.18 7
1014 [기계학습] [번역] TensorFlow Lite 튜토리얼 2 부 : 음성 인식 모델 교육 졸리운_곰 2022.11.18 13
1013 [기계학습] [번역] TensorFlow Lite 튜토리얼 1 부 : Wake Word 기능 추출 졸리운_곰 2022.11.18 10
1012 [기계학습][딥러닝] Generative Adversarial Net (GAN) PyTorch 구현: 손글씨 생성 file 졸리운_곰 2022.11.18 54
1011 [hadoop] Cloudera Quick Start VM in Hyper-V file 졸리운_곰 2022.11.14 14
1010 [기계학습][딥러닝] Flask를 이용하여 파이토치를 REST API로 베포하기 file 졸리운_곰 2022.11.12 44
1009 [기계학습][머신러닝][딥러닝] Vanilla GAN file 졸리운_곰 2022.11.08 13
1008 [기계학습][머신러닝][딥러닝] Generative Adversarial Net (GAN) PyTorch 구현: 손글씨 생성 file 졸리운_곰 2022.11.08 103
1007 [기계학습][머신러닝][딥러닝] DCGAN 튜토리얼 졸리운_곰 2022.11.08 4
1006 [PyTorch] pytorch 기본 문법 및 코드, 팁 snippets file 졸리운_곰 2022.10.20 30
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED