Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- MySQL
- Python
- Linux
- 서평단
- Tistory
- Google Analytics
- tensorflow
- Pandas
- SQL
- 독후감
- Blog
- 서평
- 한빛미디어
- 블로그
- 시각화
- 월간결산
- python visualization
- Visualization
- 리눅스
- 파이썬
- 한빛미디어서평단
- matplotlib
- 텐서플로
- MATLAB
- Ga
- 파이썬 시각화
- 매틀랩
- 딥러닝
- 티스토리
- 통계학
Archives
- Today
- Total
pbj0812의 코딩 일기
[SQL] MySQL function 생성 및 테스트 본문
0. 목표
- MySQL 에서의 function 생성 및 테스트
1. 실습하기(단순 출력)
1) function 생성
- FUNCTION_TEST 실행시 OK 출력
DELIMITER $$
DROP FUNCTION IF EXISTS FUNCTION_TEST$$
CREATE FUNCTION FUNCTION_TEST()
RETURNS VARCHAR(20)
BEGIN
DECLARE Result VARCHAR(10);
SET Result = 'OK';
RETURN Result;
END $$
DELIMITER ;
2) 에러 확인 및 수정
Error Code: 1418. This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creators variable)
- 위와 같은 에러 발생 시 아래 쿼리 실행
SHOW GLOBAL variables like 'log_bin_trust_function_creators';
- 이때 OFF 로 되어 있다면 아래의 쿼리를 실행하여 ON 으로 변경
SET GLOBAL log_bin_trust_function_creators = 1;
3) 실행
SELECT FUNCTION_TEST();
2. 실습하기(계산 결과 출력)
1) 데이터 밑작업(holiday 테이블 생성 및 데이터 삽입)
- 링크
2) 함수생성
- 시작일(StartDate), 종료일(FinishDate) 를 지정해주면 기간 사이에 포함된 holiday 의 수를 반환
- SELECT 결과를 반환하기 위해서는 INTO로 표시해줌
- RETURN 으로 반환
DELIMITER $$
DROP FUNCTION IF EXISTS HOLIDAY_COUNT$$
CREATE FUNCTION HOLIDAY_COUNT(StartDate datetime, FinishDate datetime)
RETURNS VARCHAR(20)
BEGIN
DECLARE Result VARCHAR(10);
SET Result = 0;
SELECT COUNT(*) INTO Result
FROM holiday
WHERE
holiday >= StartDate
AND holiday < FinishDate;
RETURN Result;
END $$
DELIMITER ;
3) 확인
SELECT HOLIDAY_COUNT('2021-01-01', '2021-01-10');
3. 참고
'ComputerLanguage_Program > SQL' 카테고리의 다른 글
[SQL] RIGHT JOIN 과 UNION 을 이용한 빈 키 값 채우기 (0) | 2021.09.03 |
---|---|
[SQL] ROLLUP 을 이용한 여러 방법으로 평균 구하기 (0) | 2021.08.28 |
[SQL] 서브쿼리로 휴일을 제외한 근무일수 계산하기 (0) | 2021.07.12 |
[SQL] FIRST_VALUE 를 활용한 가격이 가장 낮은 것의 아이디 구하기 (0) | 2021.07.08 |
[SQL] 연속 두 달간 해당 서비스를 이용한 회원 구하기 (0) | 2021.06.30 |
Comments