반응형
매개 변수가 있는 저장 프로시저
"를 추가하는 방법NULL이 아닐 경우 SELECT 결과를 필터링하기 전에 매개 변수를 확인하십시오.SE에서 발견된 다양한 변형을 시도해봤지만, 저에게 맞는 것은 없는 것 같습니다. MariaDB를 사용하는 IF() - THEN - ENDIF..., 다른 표기법이 있을까요?
DELIMITER //
CREATE PROCEDURE IzvjestajRacuna (
IN p_DatumOd DATETIME,
IN p_DatumDo DATETIME,
in p_ArtiklID INTEGER,
IN p_PoslovnicaID INTEGER,
IN p_KupacID INTEGER,
IN p_RadnikID INTEGER
)
BEGIN
SELECT Racun.* FROM Racun
INNER JOIN RacunStavka ON Racun.RacunID=RacunStavka.RacunID
AND RacunStavka.ArtiklID=p_ArtiklID
AND Racun.KupacID=p_KupacID
AND Racun.RadnikID=p_RadnikID
INNER JOIN Radnik on Racun.RadnikID = Radnik.RadnikID
AND Radnik.PoslovnicaID=p_PoslovnicaID
WHERE CAST(Racun.DatumVrijeme AS date) >= p_DatumOd
AND CAST(Racun.DatumVrijeme AS date) <= p_DatumDo;
END //
DELIMITER ;
call IzvjestajRacuna('2020-02-22','2020-02-25', 15, 25, 9, 35);
call IzvjestajRacuna(null, null, 15, 25, 9, 35);
절차에서 준비된 문을 사용할 수 있습니다.
여기 업데이트된 SQL이 있습니다.
DELIMITER //
CREATE PROCEDURE IzvjestajRacuna (
IN p_DatumOd DATETIME,
IN p_DatumDo DATETIME,
IN p_ArtiklID INTEGER,
IN p_PoslovnicaID INTEGER,
IN p_KupacID INTEGER,
IN p_RadnikID INTEGER
)
BEGIN
-- Assumed that if a parameter is null, we would find rows with null value on date column.
SET @where1 = IF(p_DatumOd IS NULL, " AND CAST(Racun.DatumVrijeme AS date) IS NULL", CONCAT(" AND CAST(Racun.DatumVrijeme AS date) >= ", p_DatumOd));
SET @where2 = IF(p_DatumDo IS NULL, " AND CAST(Racun.DatumVrijeme AS date) IS NULL", CONCAT(" AND CAST(Racun.DatumVrijeme AS date) <= ", p_DatumDo));
SET @sql_query = CONCAT(
"
SELECT Racun.* FROM Racun
INNER JOIN RacunStavka ON Racun.RacunID=RacunStavka.RacunID
AND RacunStavka.ArtiklID=p_ArtiklID
AND Racun.KupacID=p_KupacID
AND Racun.RadnikID=p_RadnikID
INNER JOIN Radnik ON Racun.RadnikID = Radnik.RadnikID
AND Radnik.PoslovnicaID=p_PoslovnicaID
WHERE TRUE
", @where1, @where2
) ;
PREPARE stmt FROM @sql_query ;
EXECUTE stmt;
DEALLOCATE PREPARE stmt ;
END //
DELIMITER ;
열에 값이 있으면 다음을 사용할 수 있습니다.ifnull
.
CREATE PROCEDURE IzvjestajRacuna (
p_DatumOd DATETIME,
p_DatumDo DATETIME,
p_ArtiklID INTEGER,
p_PoslovnicaID INTEGER,
p_KupacID INTEGER,
p_RadnikID INTEGER
)
BEGIN
SELECT Racun.*
FROM Racun
INNER JOIN RacunStavka ON Racun.RacunID=RacunStavka.RacunID
AND RacunStavka.ArtiklID=ifnull(p_ArtiklID, RacunStavka.ArtiklID)
AND Racun.KupacID=ifnull(p_KupacID, Racun.KupacID)
AND Racun.RadnikID=ifnull(p_RadnikID, Racun.RadnikID)
INNER JOIN Radnik on Racun.RadnikID = Radnik.RadnikID
AND Radnik.PoslovnicaID=ifnull(p_PoslovnicaID, Radnik.PoslovnicaID)
WHERE CAST(Racun.DatumVrijeme AS date) >= ifnull(p_DatumOd, Racun.DatumVrijeme)
AND CAST(Racun.DatumVrijeme AS date) <= ifnull(p_DatumDo, Racun.DatumVrijeme);
END //
COALESCE(might_be_null, fallback_value)
언급URL : https://stackoverflow.com/questions/63078381/stored-procedure-with-parameters
반응형
'programing' 카테고리의 다른 글
새 JSON 데이터로 데이터 테이블을 수동으로 업데이트하는 방법 (0) | 2023.08.19 |
---|---|
numpy의 내부 정밀도는 얼마입니까?float128? (0) | 2023.08.19 |
승인되지 않은 단순 Rest 쿼리를 실행하는 동안 예기치 않은 오류가 발생했습니다. (0) | 2023.08.14 |
jQuery: 필드 값이 null(비어 있음)인지 확인합니다) (0) | 2023.08.14 |
jquery를 사용하여 드롭다운 읽기만 만드는 방법은 무엇입니까? (0) | 2023.08.14 |