Microsoft MVP성태의 닷넷 이야기
sql과 oracle 사용시 파라메타 차이점 [링크 복사], [링크+제목 복사],
조회: 21981
글쓴 사람
임경훈 (handahan at empal.com)
홈페이지
첨부 파일
 

sql만 사용하다가 이번에 oracle을 사용하게 되었습니다.

"ORA-01036: 잘못된 변수명/번호"에러의 원인을
오늘 드디어 찾았습니다.

SQL 사용시
query = "select * from tbl ";
if (sVal != "")
query += "where f1 = @f1 "

...
sqlAdapter.SelectCommand.Parameters.Add("@f1", sVal);
...

대충 이런식으로 사용하게 되는데요.
sql에서는 Add된 파라메타가 사용되지 않아도
에러가 발생하지 않습니다.
즉 sVal이 ""값일때
@f1 파라메타는 sql 문장에 포함되지 않게 됩니다.
그럴때도 파라메타를 Add해도 상관 없습니다.

하지만 오라클에서는 Add된 파라메타는 반드시 사용되어야 한다는거죠.
따라서 위의 예제처럼 sVal == "" 일 경우에
파라메타는 Add 되어서는 안됩니다.
따라서
query = "select * from tbl ";
if (sVal != "")
query += "where f1 = :f1 "

if (sVal != "")//이 조건이 반드시 들어가야 합니다.
 sqlAdapter.SelectCommand.Parameters.Add("f1", sVal);

혹시 저와 같은 간단한 이유를 몰라 시간 낭비 하시는 분이 계시다면
조금이나마 도움이 되시길...








[최초 등록일: ]
[최종 수정일: 6/3/2006]


비밀번호

댓글 작성자
 




NoWriterDateCnt.TitleFile(s)