Microsoft MVP성태의 닷넷 이야기
sql과 oracle 사용시 파라메타 차이점 [링크 복사], [링크+제목 복사],
조회: 18212
글쓴 사람
임경훈 (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)
5937Thor... donator5/27/2024407C# 12 는 전자책이 언제쯤 나오게 될까요? [1]
5936ds4/26/20241678활성화 되어 있는 커뮤니티 발견하게 되어 기분이 좋습니다. 자주 놀러 올께요. (내용 없습니다. [2]
5935양승조 donator4/25/20241754Reflection 관련 질문 드립니다. [5]파일 다운로드1
5934양승조 donator4/24/20241259Reflection 관련 질문 드립니다. [1]
5933vict...4/23/20241206cpp 라이브러리 디버깅 방법 문의 드립니다. [1]
5932EK4/12/20241335다음 제네릭에서 널익셉션이 뜨는 이유를 알수있을까요? [1]
5931이대희4/2/20241588Windows 앱 SDK C# 템플릿의 용도가 무엇인지요? [1]
5930vict...2/22/20242622ef core, FromSqlRaw 맵핑 질문입니다. [4]
5929a2/17/20242460.Net 8 에서 디버거 변경 [1]
5928vict...2/5/20242948wpf에서 대량 데이터 보여주는 방법 추천 부탁드립니다. [1]
5926엄태영1/12/20242833잘못된 Task 사용으로 인한 데드락 관련 질문 입니다. [3]
5925Euni...12/22/20232715Visual Studio에서 nodejs 사용시 npm install -g @vue/cli 실행시 오류 [1]
5924Euni...12/21/20232735Visual Studio에서 nodejs 사용시 C:\Program Files\nodejs\\node.exe" "C:\Program Files\nodejs\\node_modules\npm\bin\npm-cli.js" prefix -g 를 찾지 못하는 설치 오류 [2]
5923정두호12/4/20233240MSSQL 데이터 전송과 공유폴더의 데이터 전송 차이점 [1]
5922Heeg...10/27/20235365C++의 double pointer를 C#에서 구현하는 방법이 잘 안됩니다. [3]
5921한예지 donator10/3/20235057마샬링 정의 및 목적이 궁금합니다. [5]
5920한예지 donator10/3/20234073C#과 WIN32 API 관계 질문드립니다. [4]
5919이건우9/27/20233582WinForm의 로딩속도 관련 질문입니다 [2]
5917한예지 donator9/14/20233647동기화 도구 질문 있습니다. [4]
5916한예지 donator9/3/20233787Thread.Sleep(500), await Task.Delay(500), Task.Delay(500) 차이점이 궁금합니다. [2]
5915한예지 donator8/30/20233715비동기 코드를 for 문 안에 작성한 경우 제어 변수가 올바르게 동작하지 않는 이유가 궁금합니다. [3]
5914한상욱8/11/20233587.net wpf에서 skiasharp 의 skelement 를 canvas로 사용 하고 있습니다. [1]
5913김태우8/10/20233598지역변수로 이해하는 메서드매개변수 게시글 댓글 [3]
5912guest4/25/20236159[참고 - 초보용] Sqlite 디비는 double이 없고 Real이 대신합니다 [3]
5911guest4/24/20234180Form1.cs와 외부 class.cs와 통신 (static async method포함) [4]파일 다운로드1
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...