Microsoft MVP성태의 닷넷 이야기
sql과 oracle 사용시 파라메타 차이점 [링크 복사], [링크+제목 복사],
조회: 21709
글쓴 사람
임경훈 (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]


비밀번호

댓글 작성자
 




1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5912guest4/25/202316807[참고 - 초보용] Sqlite 디비는 double이 없고 Real이 대신합니다 [3]
5911guest4/24/202311531Form1.cs와 외부 class.cs와 통신 (static async method포함) [4]파일 다운로드1
5910guest4/24/202311002Async 메서드와 try~catch [1]
5909guest4/22/202312013Visual Studio 구매 시(1인 개발자) [4]
5908guest4/22/202311684텅빈 원그리기 [5]
5907민성4/21/202311182안녕하세요 서버 백업 문제에 대해서 [2]
5906guest4/21/202311567Dispatcher 서비스 구현 질문 [1]
5905guest4/20/202312563tabControl의 tabPage가 여러 개일 때 순서를 바꾸기가 까다롭네요 [5]
5904guest4/18/202312490[신규자료첨부] DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [4]파일 다운로드1
5903guest4/18/202311235fileSystemWatcher 이벤트 관련 질문입니다 [2]
5902guest4/17/202312333c#으로 USB 관련 질문 [2]
5901guest4/17/202310642내솔루션 판매 시 1.0.0.0 폴더와 Sqlite 배포 [5]
5900guest4/17/202312722DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [2]파일 다운로드1
5899guest4/17/202311367Dictionary와 Linq [4]
5898차가워4/17/202311367CNTK 교육 문의 [1]
5897guest4/17/202311123Socket스레드와 UI thread [4]
5896HAN4/16/202311004c언어 return 에 대해 궁금한게 있어요. [1]파일 다운로드1
5895guest4/15/202311319Drag and Drop - 모든 컨트롤 [2]
5894송부장4/14/202312865[질문] Visual Studio 2022에서 '도구 상자 항목 선택'의 'COM 구성 요소' 탭에서 ActiveX 목록이 보이지 않습니다. [3]파일 다운로드2
5893감사합니...4/14/202310932오라클 OLEDB방식 접속 후 SELECT 'TEST' TEST_VALUE FROM DUAL의 값이 이상합니다. [1]
5892한무4/14/202310868C# 으로 백그라운드에서 워드를 실행하여 매크로 실행이 가능 할까요? [2]
5891리세4/14/202311681안녕하세요.C# 서버프로그램에서의 Mysql 쿼리문제(다중쿼리 실행)에 대해 문의드립니다. [2]
5890guest4/14/202312592C# 프리랜서로 돈 벌려면 성태님 책 마스터하면 되나요? [6]
5889전예찬4/14/202310909C# 파일 복사 관련 질문 드립니다. [3]
5888정경구4/12/202311016C# 첫 환경 세팅과 관련해서 [4]
5887HAN4/12/202311129안녕하세요 파이썬도 공유 가능 할까요? [1]
1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...