Microsoft MVP성태의 닷넷 이야기
SqlDataReader 관련 질문입니다. [링크 복사], [링크+제목 복사],
조회: 14093
글쓴 사람
하영 (johayoung222 at naver.com)
홈페이지
첨부 파일
 

질의사항 입니다.

clrprofiler를 이용하여, System.Data의 SqlDataReader에서 GetEnumerator 메소드가

수행될 때 쿼리가 수행된 후 결과 값을 InvocationTarget에서 빼내어 SqlDataReader에 담고

반복문과 Read() 메소드를 이용하여 담긴 결과 값과 컬럼의 명을 검사하려고 합니다.

위의 로직이 수행 될 경우 웹에서 Reader의 내부에 값이 비어있게 되더라구요.

제가 담긴 값과 컬럼 명을 검사하기 위해 객체를 deep copy 혹은 다른방법으로 복사하여

복사한 객체에서 값을 꺼내는 방법 혹은 꺼내지 않고 검사하는 방법은 없을지 궁금하여 질문 드립니다..








[최초 등록일: ]
[최종 수정일: 8/27/2021]


비밀번호

댓글 작성자
 



2021-08-27 01시58분
사실 이건 clrprofiler의 문제는 아니고요, DataReader의 DB cursor 문제입니다.

DataReader는 쿼리가 수행되었을 때의 resultset 결괏값을 모두 담고 있지 않고, 바로 그 resultset에서 어느 위치를 읽어와야 할지에 대한 db 서버 측 cursor 위치 정보만을 담고 있습니다. (엄밀히, 성능 문제로 인해 미리 읽어오는 데이터가 있긴 합니다.)

그래서, Read할 때마다 그 커서를 forward-only 방향으로 진행시키면서 값을 읽어옵니다.

따라서, 정상적인 방법이라면 원하는 기능을 수행할 수 없습니다. 글쎄요,,, 억지로 해본다면, (지금처럼 그냥) clrprofiler 측에서 datereader를 모두 읽어오도록 만든 다음, 그 데이터를 감싸서 DataReader 인터페이스를 추가한 특정 개체를 생성해 사용자 프로그램에 반환하는 정도가 되지 않을까 싶습니다.
정성태
2021-08-27 02시03분
[하영] 엇 넵 아무래도 웹쪽에서도 SqlDataReader에서 동일하게 데이터를 꺼내려고 하면 똑같기때문에..

정확한 설명 감사드립니다.

혹시, 생각하고 있는 방법이 하나 있긴한데..

TraceMethod가 ExecuteReader일 경우에만

SqlCommand에서 executeReader를 수행하여, 받은 reader에서 값을 꺼내면 웹쪽에서 문제가 없던 것으로 기억하는데

이렇게 구현할 경우에 쿼리가 내부적으로 한번 더 수행되는 것이라고 판단하였었는데

당연히 좋은 방법은 아니겠죠?.... 성능적으로 문제를 일으킨다던지 할 수 있을 것 같아서요
[guest]
2021-08-27 02시09분
[하영] 아 그리고, 질문은 아니지만 제가 java만 하다가 다른 개발 건으로 정성태님의 C# 7.3 프로그래밍 책을 구매하여
보다가 해당 사이트를 알게되었고 정말 많은 정보를 접하고 질문에 대한 답변 달아주심에 너무 감사드립니다 :)
[guest]
2021-08-27 02시35분
말씀하신 것처럼 ExecuteReader를 한 번 더 실행해도 될 것입니다. 그렇긴 한데, 이 문제는 profiler 개발자가 정하기보다는 해당 clrprofiler를 사용하는 측의 동의를 구해야 할만한 문제로 보입니다. ^^;

그나저나, Java 하시다가 C#을 하는 건데 C/C++까지 알아야 하는 profiler를 먼저 만질 정도면 천상 개발자시군요. ^^
정성태
2021-08-27 03시01분
[하영] 일단, 먼저 해결해야할 이슈들이 산더미라서 현재 생각해놓은 방법으로 꼭 한번 구현해보도록 하겠습니다.
추가로 말씀해주신 부분은 수정관련에 대한 부분을 찾아본 배포 이전에는 꼭 동의를 구하도록 하겠습니다!
방긋 웃을 수 있는 칭찬 감사드립니다.

혹시, 글과는 조금 벗어난 질문인데 IIS 6에서 돌아가는 웹(CRM 솔루션)과 AD(Active Directory)가 연동(연계)되어진 시스템이 있는데
regedit에서 확인할 수 있는 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\ProfileList 내부에서 IIS 응용프로그램풀
의 사용자프로필 로드를 True로 바꾸어주었을 경우 키 값을 확인할 수 있는 것으로 알고 있습니다. NetworkService 계정을 이용한 경우 혹은 이외의 경우에
키 값이 보이지 않는 경우도 있다고 알고 있구요. 추가로 찾아보다가 정성태님이 작성해주신 글을 참고하여, https://www.sysnet.pe.kr/2/0/1192
setEnviroment 옵션을 사용하여 true로 직접 지정해준 뒤 iisreset을 수행하였습니다. 그런데, 해당 옵션때문에 에러가 발생하였고 사용자프로필을 로드할 수 없다는
에러메시지를 만나게 되었습니다. 해당 응용프로그램풀의 고급설정에서는 ID가 network service라는 것 이외에는 눈에뛰게 다른점은 없었습니다.
질문 사항입니다. 혹시 AD(Active Directory) 때문에 사용자 프로필을 로드할 수 없는 것인지 궁금하며, 혹시 조금 더 확인해볼 수 있는 사항이 있을지 궁금합니다.
[guest]
2021-08-27 03시04분
[하영] 말씀못드린 부분이 있어 말씀드립니다. https://www.sysnet.pe.kr/2/0/1192 글을 참고하여,
setEnviroment="true" 옵션을 CRM + AD 서버가 아닌 제가 가진 IIS 내부에서는 해당 옵션이 아무 문제
없이 사용자프로필이 정상적으로 로드되었던 것 확인을 했었습니다!..
[guest]
2021-08-27 03시34분
그러니까, Network Service 계정인 경우 AD 환경에서는 setEnviroment=true로 설정하면 오류가 나는가를 묻는 건가요? 원칙상으로는 발생할 이유가 없습니다.
정성태
2021-08-27 03시49분
[하영] 넵 맞습니다.
목표는 해당 환경에서 응용프로그램풀에 대한 사용자 프로필 로드가 정상적으로 되는 것 이고
사실 AD서버라는 것을 이번에 처음 듣게되어, 직접 찾아보고 구축하여 웹과 연동하여 테스트 해보아야할 것 같습니다.
답변 감사드립니다!
[guest]

... 61  62  [63]  64  65  66  67  68  69  70  71  72  73  74  75  ...
NoWriterDateCnt.TitleFile(s)
1053폭풍코딩4/19/201216508스마트클라이언트 ctrl-c 복사가 작동하지 않습니다. [1]
1052에슈리온4/17/201232940ClickOnce 배포시 클라이언트의 설치경로를 지정할 수 없나요? [1]
1051최정수4/10/201219823WCF 클라이언트 비정상 종료 관련 [1]
1050에슈리온4/6/201221994관리자 권한과 ClickOnce, 그리고 Bootstrapper문제 [6]
1049김성혁4/4/201216575스마트클라이언트 stand-alone 방식의 배포 문제.. [1]
1048C#조으다3/27/201220143어셈블리 로드 / 언로드와 관련해서.. [6]
1047김우형3/23/201217724WCF 서비스를 이용한 데이터 전송 중 Exception 문의 [1]
1044임동찬2/29/201217594웹에서 COM Exception.. [2]
1043박성준2/24/201216134Lazy<T> 의 지연객체 생성 전에 실 객체의 Attribute분석 [2]파일 다운로드1
1042이성환2/20/201216565BlockingMethod에 빠진 스레드를 즉시 죽이고 싶습니다...;ㅅ; [2]파일 다운로드1
1039김재영2/15/201215892어셈블리에 사용자마다 다른 값을 적용하여 자동 빌드 방법이 있을까요? [2]
1037윈드로니2/12/201217317WPF 관련 질문 드립니다. [2]
1035임동찬2/9/201215681XML, XSD, XMLCodeGenerator 관련 [2]
1033곽성현2/7/201216195훔..윈도우 디바이스 드라이버 관련 [1]
1030궁빈2/2/201218627msbuild를 이용한 웹게시 및 자동 Dist 방법론에 대해 질문 드립니다!! [6]
1028신정환1/30/201215882기존 legacy Windows application이 WoA 환경에서 동작되지 않는 이유가 무얼까요? [2]
1026노현철1/19/201217852WPF가 XP에서 느리게 로딩되는 현상에 대해 질문드립니다. [4]
1025궁그미1/18/201218798네이버 소켓 로그인 이해가 안되는점이 있는데요 [2]
1022선무당1/11/201216880TFS 에서 공통 Assembly 공유 방법에 대해서 해결책이 없을까요? [2]
1021김재영1/8/201215928대리자를 메소드 파라메터로 넘겨도 됩니까? [2]파일 다운로드1
1019남산골11/13/201918524안녕하세요!! 성태님~~ [3]
1018강한구12/29/201121847WPF ClickOnce 배포시 콤포넌트 dll 다운로드 문제에 대하여 질문 있습니다. [1]
1017임동찬12/28/201118740smart client와 xbop, silverlight [6]
1015개똥이12/22/201116180RMCLOCK 설정 관련 질문이요ㅜ [2]
1011사길수12/16/201116235hyper-v 이더넷 카드 관련 문의 좀 드립니다. [1]
1006루로니12/13/201118358윈도우7과 XP의 DLL후킹 처리에 관해서 질문입니다. [3]
... 61  62  [63]  64  65  66  67  68  69  70  71  72  73  74  75  ...