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

... 31  32  33  34  35  36  37  38  [39]  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
4911필승11/6/201716404WebBrowser 컨트롤 사용법에 대해 궁금합니다. [2]
4910진우11/6/201716169람다 초보 질문 드립니다. [2]
4909필승11/5/201717164TextBox에 관해 질문 드립니다. [5]
4908필승11/1/201721635특정 시각에 프로그램 종료 또는 재시작시 오류 발생 [8]
4907심너울10/29/201716680선생님이 쓰신 "시작하세요! C# 7.1~"으로 공부하고 있는데요~ [2]
4906guest10/25/201715590.net core, .net standard 관련해서 궁금합니다 [2]
490510/25/201714930watermark 관련문의 [1]
4903Ho10/25/201715237간단한 서버를 구현해 보고 싶습니다. [2]
4902황재승10/22/201716589C# 7.1 프로그래밍 왕초보자도 이해할 수 있는 수준인가요? [1]
4901김레오10/17/201721909c# 프로그램 난독화 도구인 confuserex라는 도구를 사용하다 여쭙습니다. [2]
4900황준범10/12/201716960ClickOnce 배포관련 질문드립니다. [1]
4899Ques...9/28/201718987C# 프로그램이 "응답 없음" 시에도 계속 독립적으로 돌아가는 타이머 생성법 [3]
4898ssdrm9/27/201715543Clickonce 실행시 보안에 막힙니다 ㅠ [1]
4897김태진9/23/201715951윈도우7 작업관리자의 상세(details)탭 생성에 대해 여쭙습니다. [1]
4896장진국9/19/201717230안녕하세요 WPF 에서 Window객체가 가비지 콜렉션에 의해 수집되지 않는거 같아서 문의드립니다. [1]
4895Ques...9/18/201717565Generic 에 관하여 질문드립니다. [5]
4894얼마전6...9/14/201720389C# 7.1에서 보강된 부분만 PDF로 제공하는 건 아니되나요? [2]
4893BigII9/14/201718578타 언어(JAVA, PHP 등)에서 받은 RSA 개인키 문자열을 이용하여 내용 복호화 가능 여부 [4]
4892Ques...9/13/201716746서브 폼에서는 무거운 작업을해도 속도가 빠를까요 ?? [1]
4891윤현수9/11/201717595Taskbar에 관한 질문입니다. [5]
4890제발9/11/201715933 시작하세요! C# 6.0 프로그래밍 책이 절판됐나요? [5]파일 다운로드1
4889낙낙이9/7/201715376안녕하세요! xsl관련 이야기입니다. [1]
4888heyh...9/6/201715226클릭원스를 수동으로 배포 시 업데이트 할 때 [1]
4887이경현9/4/201716035Windows server 2012 파일 없어짐 현상... [1]
4886질문자9/1/201717865disconnecteditem에 대하여 아시나요? [4]파일 다운로드1
4883솔솔8/30/201716073dataview에서 select한 index 가져오기 [1]
... 31  32  33  34  35  36  37  38  [39]  40  41  42  43  44  45  ...