본문 바로가기

Database

(150)
오라클 날짜 데이터 | 일 시 분 초 로 나타내는 방법 오라클 날짜 데이터 | 일 시 분 초 로 나타내는 방법 안녕하세요. 오늘은 오라클 간만에 팁을 공유 하려고 작성을 합니다. 날짜 데이터 사이의 차이를 구하는 SQL을 작성 해보았습니다. 먼저 아래와 같이 테스트용 테이블과 연습용 데이터를 넣어보겠습니다. 테스트 데이터 입력 아래 SQL을 실행하여 테스트 데이터를 입력합니다. create table time_gap ( start_Date date, end_Date date ); INSERT INTO TIME_GAP (START_DATE, END_DATE) VALUES (TO_DATE('2022-03-21 10:43:42', 'YYYY-MM-DD HH24:MI:SS'), TO_DATE('2022-03-23 10:48:43', 'YYYY-MM-DD HH24:M..
[over 함수]sql에서 합계나 평균등 집계함수의 결과를 group by 없이 출력하기 sql에서 합계나 평균등 집계함수의 결과를 group by 없이 출력하기 안녕하세요. 이번 포스트에서는 over함수에 대해서 한번 같이 공부 해보도록 하겠습니다. 아마 유용하게 잘 쓰실수 있을 것 입니다. 실습 준비 다음과 같은 테이블을 생성하고, 데이터를 입력하도록 합니다. #스크립트에서 schema단위는 빠져 있습니다. create table rows_sql_test ( group_id varchar(10), seq int, created_goods_cnt int ); INSERT INTO rows_sql_test (group_id, seq, created_goods_cnt) VALUES ('A', 1, 123); INSERT INTO rows_sql_test (group_id, seq, create..
mariadb instr 함수 커스트마이징 하기 (오라클 버전 파라미터 적용) mariadb instr 함수 커스트마이징 하기 (오라클 버전 파라미터 적용) 안녕하세요. 오늘은 mariadb를 사용하면서 불편한 부분 하나를 좀 개선 했습니다. 이미 뭐 아실만한 분들은 그렇게 사용을 하고 계시겠지만~~ 그래도 편하게 사용 하시라고~ instr 함수를 mariadb에서도 오라클과 같이 사용 할 수 있게 만들어 보았습니다. 1. instr 함수 instr 함수는 어떤 문자열 안에서 특정문자가 몇번째에 위치해 있는지 그 위치값을 반환하는 함수이며, 없다면 0을 반환 하도록 되어 있습니다. 한번 볼까요? select instr('abcabcabcabc','a') from dual; 위와 같이 오라클에서 실행하면 다음과 같이 나오게 됩니다. 당연히 첫번째 위치에 a가 있으니 1이 반환이 되는..
mariadb procedure exception 처리 예제 mariadb procedure exception 처리 예제 안녕하세요. 오늘은 mariadb에서 procedure나 function을 개발하실때 exception 예외처리를 어떻게 하는지에 대한 예제를 기록해보도록 하겠습니다. 1. exception 이란? mariadb에서 procedure나 function을 사용하실때 exception을 이용하여 SQL에러나 데이터가 없을때, 혹은 어떤 로직의 상황에서 벗어나야 할때 exception처리를 해줘야 정확한 SP를 작성 할 수 있습니다. 예외처리를 잘 해야 안그래도 디버깅도 어려운 procedure나 function을 제대로 사용 할 수 있겠죠. 2. exception 종류 저는 exception을 크게 3종류를 사용하고 있습니다. 하나는 not fou..
mysql 함수를 이용한 인덱스 생성하기 feat.virtual column mysql 함수를 이용한 인덱스 생성하기 feat.virtual column 안녕하세요. 이번에는 mysql에서 함수를 이용한 인덱스를 생성하는 방법은 안내 해드리려 합니다. 오라클에선 잘쓰던 함수를 이용한 인덱스를 Mysql 이나 Mariadb에서 사용 할 수 없어 답답 했었는데, 좋은 정보를 알게되어 공유를 해드립니다. 가상 컬럼 이란? Mysql 5.7 부터 지원되는 가상 컬럼은 가상의 칼럼을 둬서 수식과 조건문을 사용해 데이터의 가공 결과를 저장하는 것을 말합니다. 사용 방법에는 PERSISTENT(stored)와 VIRTUAL(generated-only)이라는 두 가지 타입이 존재합니다. 디폴트는 PERSISTENT 입니다. PERSISTENT virtual columns은 실제 데이터가 데이터..
error 1422 Explicit or implicit commit is not allowed in stored function or trigger 마리아DB 펑션 error 1422 Explicit or implicit commit is not allowed in stored function or trigger 마리아DB 펑션 안녕하세요. MariaDB에서 펑션를 개발하는 도중에 만난 에러에 대하여 처리 방법을 공유코자 포스트를 남깁니다. error 1422 이며, function을 개발하는 도중에 만나게 되었습니다. error 1422 Explicit or implicit commit is not allowed.... 해당 에러는 에러 메시지만 봐도 내용을 대강 알 수 있겠죠. 아래와 같이 파파고에서 친절하게 해석을 해줍니다. commit을 쓰지 못한다 인데.. 제가 작성한 펑션에는 커밋이 없었습니다. (뭘 많이 가렸죠? 죄송합니다..) 아무튼, commit이 ..
오라클 utl_encode.text_encode mariadb에선 어떻게 써야 하나? 오라클 utl_encode.text_encode mariadb에선 어떻게 써야 하나? 안녕하세요. 오라클 to Mariadb로 전환 프로젝트를 진행 하고 있습니다. SP들이 몇개 있어서, procedure 변환도 함께 진행을 하고 있습니다. 그와중에 나오는 몇가지 오라클 함수들을 mariadb에서 어떻게 구현을 해야 하는지 정리를 해두겠습니다. UTL_ENCODE UTL_ENCODE는 호스트 간의 데이터를 전송할 수 있도록 표준 인코딩 기술로 인코딩하는 함수를 제공하는 패키지 입니다. 이중에서 우리가 사용한 TEXT_ENCODE 은 문자 집합을 갖는 문자열을 인코딩하는 함수이며 변경할 문자 집합에 따라 텍스트를 변환하고 인코딩 합니다. 사용법은 다음과 같죠. select utl_encode.text_en..
update auto_increment 컬럼, order by 로 error-1062 없이 실행 하기 update auto_increment 컬럼, order by 로 error-1062 없이 실행 하기 안녕하세요. 혹시, auto_increment 로 된 primary key 컬럼을 업데이트 할때 error-1062 Duplicate entry '1' for key 'orderby_test.PRIMARY' 에러가 나는것을 경험 하신적 있으신가요? 꼭 auto_increment가 아니더라도, 숫자로된 primary key 컬럼의 값을 균일하게 변경 하면서 update 할때 에러가 나는 경우가 있으셨을 겁니다. 해당 내용에 대한 실습을 한번 해보도록 하겠습니다. update, order by와 함께! 자, 실습에 필요한 데이터를 생성 해보도록 하겠습니다. 다음과 같이 테이블을 만들고 데이터를 넣도록 할께요..