Microsoft MVP성태의 닷넷 이야기
SqlDataReader 관련 질문입니다. [링크 복사], [링크+제목 복사]
조회: 6200
글쓴 사람
하영 (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)
5828김재영2/19/20233149장기적으로는 this 구문을 안쓰는게 맞을까요? [2]
5827lee2/18/20233065파이썬 설치 오류 질문입니다 [1]
5826Syong2/14/20233649Socket 관련 Leak (OverlappedAsyncResult, OverlappedData) 관련 문의 [7]파일 다운로드1
5825박성원2/14/20233223Listview 컨트롤의 화면 전환 시 갱신 속도 [1]
5823검은콩2/13/20233822catch(Exception ex)의 line번호를 쉽게 알 수 없는지요? [7]
5822김지우2/11/20233096책을 보면서 sync, async 이해가 되지 않는 부분이 있습니다. [5]파일 다운로드2
5821검은콩2/9/20233121Async 신뢰성과 소켓데이터 [4]
5820차가워2/8/20233181다른 프로세스 실행 후 포커스 가져오기 [3]
5819취준생2/7/20233333WPF 관련 실무가 궁금합니다. [3]
5818윤길2/7/20232782ObservableCollection 에서 INotifyPropertyChanged 구현해야하나요? [2]
5817흰털너부리2/7/20232921배포 시 winform 실행 콘솔로그 보는 방법 [1]
5816흰털너부리2/6/20232735.net core json array validation 질문 드립니다. [1]
5815김재영2/6/20232855종단간 암호화에 대해 시나리오인데 타당한 시나리오일까요? [2]
5814한예지 donator2/6/20233188decompile? [9]
5813김재영2/5/20233082openssl genrsa 2048시 키 생성이 다르게 됩니다. - 파일첨부 [4]파일 다운로드1
5812김재영2/5/20233364openssl genrsa 2048시 키 생성이 다르게 됩니다. [2]
5811치르바2/3/20233191MiniDumpWriteDump API로 덤프수집을 했는데요.. [3]
5810이건우1/31/20233294윈도우서비스를 통한 웹통신관련 질문입니다 [3]
5809이상훈1/31/20233734다채널 영상 디스플레이어 개발 관련 질문입니다. [3]
5808근우1/30/20233412WPF 에서 UserControl 과 ControlTemplate 의 차이점은 무엇인가요? [6]
5807궁금맨1/28/20234567C# 10 책에 나온 예제의 결과가 제 컴에서는 좀 달라서요. 이유가 궁금합니다. [1]
5806스레드1/25/20233079총정리 - 다양한 스레드들 [초안] [1]파일 다운로드1
5805어웨이트1/25/20232946Taskcontinuewith vs Async/Await [2]파일 다운로드1
5804나이많은...1/25/20232803MS의 Dependency Injection(DI)에 AddSingleton으로 등록된 객체의 Event 등록후 사용시 앱 종료시 별도로 Event를 해지해야 하나요? [2]
5803dssc...1/24/20233031드라이브 문자를 통해서 물리 디스크 명칭을 알아내고 싶습니다. [1]
5802모바일앱1/22/20232925XAMARINE vs Android Studio [7]
1  2  3  4  [5]  6  7  8  9  10  11  12  13  14  15  ...