Microsoft MVP성태의 닷넷 이야기
글쓴 사람
감사합니다.
홈페이지
첨부 파일
 

안녕하세요?
항상 도움 주셔서 감사합니다.

특이한 현상을 경험해서 이런 경험 해보시고 해결하신 분이 있을까 해서 문의드립니다.


OLEDB 방식 오라클 클라이언트 프로그램을 PC1과 PC2에서 실행하는데 서로 값이 다르게 나와서 해결할 수 있는 방법이 있는지 문의드립니다.

PC1과 PC2는 윈도우 서버이며 서로 버전이 다릅니다.

그리고 PC1과 PC2는 서로 다른 ODAC 버전이 설치되어 있습니다.



오라클 OLEDB방식 접속 후 SELECT 'TEST' TEST_VALUE FROM DUAL의 값을 C# DataTalbe 로 가져온 다음

String 변수값에 넣으면 PC1은 'TEST'로 가져오고 PC2는 'TEST____________' 이렇게 공백이 들어간 상태로 가져오네요.

마치 ORACLE의 VARCHAR2 와 CHAR의 자료형을 가져오는 것 처럼 값을 가져옵니다.

PC2와 동일한 버전의 ODAC가 설치되어 있는 또 다른 PC에서 OLEDB 방식으로 접속해서 가져오면 'TEST' 이렇게 값을 가져오네요.



테이블의 컬럼값을 가져오지 않고 저렇게 SELECT 구문에 문자열 값을 지정했을 때 해당 값의 형태를 VARCHAR2로 설정할 수 있는

ODAC의 OLEDB 설정이나 C# 코드 자체에서 설정, 혹은 다른 설정할 수 있는 방법이 있는지 궁금합니다.

C#에서 string변수 값으로 가져와서 Trim 처리를 하거나 오라클 쿼리의 CAST를 사용해서 캐스팅 하지 않고 혹시 해결할 수 있는 방법 아시는 분 가르쳐 주시면 감사하겠습니다.


즐거운 주말 보내세요.








[최초 등록일: ]
[최종 수정일: 4/14/2023]


비밀번호

댓글 작성자
 



2023-04-14 10시38분
DataTable을 경유하지 않으면 그런 현상이 없는 건가요? 즉, 순수하게 SqlCommand로 SELECT하면 공백 문자가 따라오지 않는 건지 확인해 보세요.

그리고, 아마 Oracle도 Query Profiler 같은 것이 있을 것입니다. 그걸로 한번 체크를 해보세요. 분명히 2대의 PC 간에 다른 점이 있을 것입니다.
정성태

[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5923정두호12/4/202317MSSQL 데이터 전송과 공유폴더의 데이터 전송 차이점 [1]
5922He...10/27/20231873C++의 double pointer를 C#에서 구현하는 방법이 잘 안됩니다. [3]
5921한예지10/3/20232844마샬링 정의 및 목적이 궁금합니다. [5]
5920한예지10/3/20231772C#과 WIN32 API 관계 질문드립니다. [4]
5919이건우9/27/20231533WinForm의 로딩속도 관련 질문입니다 [2]
5917한예지9/14/20231635동기화 도구 질문 있습니다. [4]
5916한예지9/3/20231751Thread.Sleep(500), await Task.Delay(500), Task.Delay(500) 차이점이 궁금합니다. [2]
5915한예지8/30/20231686비동기 코드를 for 문 안에 작성한 경우 제어 변수가 올바르게 동작하지 않는 이유가 궁금합니다. [3]
5914한상욱8/11/20231654.net wpf에서 skiasharp 의 skelement 를 canvas로 사용 하고 있습니다. [1]
5913김태우8/10/20231853지역변수로 이해하는 메서드매개변수 게시글 댓글 [3]
5912guest4/25/20233420[참고 - 초보용] Sqlite 디비는 double이 없고 Real이 대신합니다 [3]
5911guest4/24/20232318Form1.cs와 외부 class.cs와 통신 (static async method포함) [4]파일 다운로드1
5910guest4/24/20232075Async 메서드와 try~catch [1]
5909guest4/22/20232284Visual Studio 구매 시(1인 개발자) [4]
5908guest4/22/20232213텅빈 원그리기 [5]
5907민성4/21/20231996안녕하세요 서버 백업 문제에 대해서 [2]
5906guest4/21/20232101Dispatcher 서비스 구현 질문 [1]
5905guest4/20/20232134tabControl의 tabPage가 여러 개일 때 순서를 바꾸기가 까다롭네요 [5]
5904guest4/18/20232220[신규자료첨부] DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [4]파일 다운로드1
5903guest4/18/20231889fileSystemWatcher 이벤트 관련 질문입니다 [2]
5902guest4/17/20232341c#으로 USB 관련 질문 [2]
5901guest4/17/20232105내솔루션 판매 시 1.0.0.0 폴더와 Sqlite 배포 [5]
5900guest4/17/20232950DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [2]파일 다운로드1
5899guest4/17/20232232Dictionary와 Linq [4]
5898차가워4/17/20232028CNTK 교육 문의 [1]
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...