Microsoft MVP성태의 닷넷 이야기
SqlDataReader 관련 질문입니다. [링크 복사], [링크+제목 복사]
조회: 6199
글쓴 사람
하영 (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)
5617Edun2/25/20224361ArgumentOutOrRangeException에러 발생 [2]파일 다운로드1
5616csha...2/24/20224272readonly struct로 선언된 구조체를 특정 클래스에서 멤버변수로 가지는 경우 [1]
5615장성욱2/22/20226472SetThreadAffinityMask를 이용한 쓰레드 지정하는 방법에 대해 궁금합니다. [4]
5614민우2/22/20225819SSL 통신 문의 [6]
5613김인태2/22/20224308서버와 PC 간의 어플리케이션 성능 차이 [1]
5612팬입니다2/20/20224121Kastrel 서버 관련 [1]
5611차가워2/19/20224342stopWatch 늘어짐 문의 [3]
5610차가워2/18/20224230Stopwatch 늘어짐 문제 [1]
5609cs린이2/15/20224565c# 함수의 호출 방식에 대해 궁금합니다! [2]
5608지호2/10/20225091시작하세요 C# 8.0 중 제네릭타입의 IEnumerable [3]파일 다운로드1
5607이로운2/10/20224336안녕하세요. 궁금한게 있어서 질문드립니다. [1]
5605강성봉2/10/20224335TCP PSH flag 패킷 수신 에러 [1]
5604LW2/9/20224464VISUAL STUDIO 2019 ==> 2020 설치시 오류가 생겨서 문의드립니다. [3]
5603김진명2/9/20225753C# 10.0 출간은 언제쯤 계획하고 계신가요? [1]
5602신갑영2/8/20224562윈폼에 대해서 질문 드립니다. [1]
5601김인태2/4/20224790setup project 관련 [7]
5600itkim2/3/20225662윈도우 서버 계정 패스워드 인증 문의 [5]
5599레드골드2/3/20226150c#으로 ms word 제어 가능할까요? [6]
5598jaew...2/2/20224833Dictionary는 참조형식인가요?? [1]
5597재원2/2/20225175c# 9.0에 대한 내용을 받을 수 있나요? [1]
5596kss1/26/20224898듀얼 모니터 환경에서 wpf 프로그램 크기 변경 [2]
5594mira...1/25/20224548안녕하세요 try~catch 와 SuspendLayout~ResumeLayout 간 호출 문의드립니다! [2]
5593C#스터디1/12/20225474TaskAwaiter 구현 질문 입니다. [1]
5591유지킴12/24/20215089outofmemory in 32bit [2]파일 다운로드1
5590kss12/23/20214540포인터 메모리 에러 [1]
5589초급12/22/20214732c# -> 라즈베리파이(db 접속)시 에러 발생 [7]
1  2  3  4  5  6  7  8  9  10  11  12  [13]  14  15  ...