Microsoft MVP성태의 닷넷 이야기
SqlDataReader 관련 질문입니다. [링크 복사], [링크+제목 복사]
조회: 6134
글쓴 사람
하영 (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]

1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5853pa3/16/20233141오피스 2016 업데이트 후 파일 출력 불가 [1]
5852guest3/16/20232822입력 foreach 검색/출력 foreach [3]
5851guest3/15/20233127foreach내 list변경 [10]
5850독서가3/14/20232810C#에서 동적dll 사용시 문의입니다. [4]파일 다운로드1
5849guest3/9/20232799C# wpf로 Web에서 구동되는 hts가능한가요? (노트북없고 스마트폰 없음) [4]
5848민성3/9/20232717도움 요청드립니다. [2]파일 다운로드1
5847guest3/7/20232841SQlike Like 구문 - 1시간째 인데 안되네요 [13]
5846Huuu...3/7/20232551웹 다운로드에 대한 고찰 [5]파일 다운로드1
5845guest3/7/20232582C# Split함수의 불친절함 [1]
5844까망이3/7/20232704c# 무료 디컴파일러는 어떤게 좋습니까? [1]
5843guest3/7/20232640판매 후 dll 등 에러 [5]
5842kr13/6/20232680publish 할 때 분석기 관련 dll 제외 [5]
5841guest3/3/20232886프로그램 판매 시 - Upgrade 버전 판매 [2]
5840joe3/2/20232974C# 클래스 라이브러리 수정 -> C++에서 참조시 함수 목록 갱신되지 않음. [4]파일 다운로드1
5839guest3/2/20233626윈도우 서비스 프로그램 - FORM 애플리케이션 감시서비스 [8]
5838랄랄라3/1/20232814event 사용 시 두 표현의 차이점이 있을까요? [1]
5837감사합니...2/28/20232966오라클 DB서버 접속관련 문의 드립니다.(Load Balancing, HA Events) [2]
5836박지범2/27/20232765static instance의 initialize 순서가 보장되나요? [6]
5835주민호2/25/20235508Windows Software Development Kit - 최신버전 1개 남기고 다 삭제하면 안되는지요? [10]파일 다운로드1
5834guest2/24/20232802Python IDE - 비주얼스튜디오 [3]
5833무지남2/23/20232526Async 메서드 그리고 나서 Bool 메서드 [5]
5832김지우2/21/20232805event와 delegate의 차이 , event를 써야하는 이유 [1]
5831이우람2/20/20233041ref 전역변수가 pinned가 될수 있나요? [2]
5830냉수마찰2/19/20233371C# GridView에 Column별 데이터 추가하는 방법에 대해 [1]
5829수박942/19/20233360키움 API를 윈폼과 WPF의 네임스페이스 없이 콘솔이나 WinUI3에서 사용할 수 있는 방법이 있나요? [2]파일 다운로드1
5828김재영2/19/20233112장기적으로는 this 구문을 안쓰는게 맞을까요? [2]
1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...