Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 1개 있습니다.)
MsiGetProductInfo failed to retrieve ProductVersion for package with Product Code = '{...}'. Error code: 1605.


SQL Server 2008 R2를 설치하는 중에 오류가 발생했습니다. 근데 오류 지점이 이상해서 어느 단계까지는 이미 설치가 되어버린 상태였습니다. 이걸 어쩌나... 싶어서 제어판에서 삭제를 해보았는데 이마저도 여의치 않게 삭제가 안 됩니다. ^^;

그래서, SQL Server의 Uninstall 관련 레지스트리를 모두 삭제한 후 다시 설치 시도를 해보았는데, 다음과 같은 오류가 발생했습니다.

MsiGetProductInfo_failed_to_retrieve_1605_1.png

SQL Server Setup has encountered the following error:
MsiGetProductInfo failed to retrieve ProductVersion for package with Product Code = '{4815BD99-96A4-49FE-A885-DCF06E9E4E78}'. Error code: 1605..



이 오류는 ^^; 방법이 없더군요. 아무리 레지스트리에 남김없이 삭제를 해도 위의 실패는 계속해서 발생했습니다.

다행히 검색 결과,,, 아주 정확한 ^^ 해결책이 나왔습니다.

Upgrade from SQL 2005 to SQL 2008 might fail with MsiGetProductInfo error
; http://blogs.msdn.com/b/sqlserverfaq/archive/2009/06/13/upgrade-from-sql-2005-to-sql-2008-might-fail-with-msigetproductinfo-error.aspx

방법은 간단합니다. "Product Code" == "{4815BD99-96A4-49FE-A885-DCF06E9E4E78}"에서 앞의 Guid 4byte를 그대로 거꾸로 뒤집어서 "99DB5184"라는 문자열을 구합니다. (실수하실까봐 말씀드리면 2byte 씩 뒤집는 것이 아니고 한 글자씩 뒤집는 겁니다.)

얻어진 문자열로 "HKEY_CLASSES_ROOT\Installer\UpgradeCodes" 하위에서 "검색"을 해보면 다음과 같은 결과를 얻을 수 있습니다.

MsiGetProductInfo_failed_to_retrieve_1605_2.png

검색 대상이 된 문자열 값을 포함하고 있는 "79C8EFA32BFF8734F9F64E1FA6A526D7" 레지스트리 키를 삭제하면 됩니다. (참고로, 제품을 다시 설치하는 중에 위와 같은 과정이 되풀이 될 수 있습니다. 저는 8번 정도 되풀이했던 것 같습니다. ^^;)

설치/제거 작업이 점점 더 복잡해지는군요. ^^



[이 토픽에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 2/11/2023]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2014-06-24 08시46분
[우니] 사랑합니다~ 님은 천재!
[guest]
2014-06-24 01시38분
단지 다른 분이 이미 밝혀놓은 것을 ^^ 찾아서 정리했을 뿐입니다.
정성태

1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13804정성태11/7/20247072Linux: 101. eBPF 함수의 인자를 다루는 방법
13803정성태11/7/20246653닷넷: 2309. C# - .NET Core에서 바뀐 DateTime.Ticks의 정밀도
13802정성태11/6/20247059Windows: 269. GetSystemTimeAsFileTime과 GetSystemTimePreciseAsFileTime의 차이점파일 다운로드1
13801정성태11/5/20246871Linux: 100. eBPF의 2가지 방식 - libbcc와 libbpf(CO-RE)
13800정성태11/3/20247848닷넷: 2308. C# - ICU 라이브러리를 활용한 문자열의 대소문자 변환 [2]파일 다운로드1
13799정성태11/2/20245616개발 환경 구성: 732. 모바일 웹 브라우저에서 유니코드 문자가 표시되지 않는 경우
13798정성태11/2/20247277개발 환경 구성: 731. 유니코드 - 출력 예시 및 폰트 찾기
13797정성태11/1/20247265C/C++: 185. C++ - 문자열의 대소문자를 변환하는 transform + std::tolower/toupper 방식의 문제점파일 다운로드1
13796정성태10/31/20246776C/C++: 184. C++ - ICU dll을 이용하는 예제 코드 (Windows)파일 다운로드1
13795정성태10/31/20245967Windows: 268. Windows - 리눅스 환경처럼 공백으로 끝나는 프롬프트 만들기
13794정성태10/30/20246049닷넷: 2307. C# - 윈도우에서 한글(및 유니코드)을 포함한 콘솔 프로그램을 컴파일 및 실행하는 방법
13793정성태10/28/20246017C/C++: 183. C++ - 윈도우에서 한글(및 유니코드)을 포함한 콘솔 프로그램을 컴파일 및 실행하는 방법
13792정성태10/27/20245404Linux: 99. Linux - 프로세스의 실행 파일 경로 확인
13791정성태10/27/20245862Windows: 267. Win32 API의 A(ANSI) 버전은 DBCS를 사용할까요?파일 다운로드1
13790정성태10/27/20245369Linux: 98. Ubuntu 22.04 - 리눅스 커널 빌드 및 업그레이드
13789정성태10/27/20246332Linux: 97. menuconfig에 CONFIG_DEBUG_INFO_BTF, CONFIG_DEBUG_INFO_BTF_MODULES 옵션이 없는 경우
13788정성태10/26/20245134Linux: 96. eBPF (bpf2go) - fentry, fexit를 이용한 트레이스
13787정성태10/26/20246492개발 환경 구성: 730. github - Linux 커널 repo를 윈도우 환경에서 git clone하는 방법 [1]
13786정성태10/26/20246266Windows: 266. Windows - 대소문자 구분이 가능한 파일 시스템
13785정성태10/23/20245623C/C++: 182. 윈도우가 운영하는 2개의 Code Page파일 다운로드1
13784정성태10/23/20246226Linux: 95. eBPF - kprobe를 이용한 트레이스
13783정성태10/23/20245742Linux: 94. eBPF - vmlinux.h 헤더 포함하는 방법 (bpf2go에서 사용)
13782정성태10/23/20245423Linux: 93. Ubuntu 22.04 - 커널 이미지로부터 커널 함수 역어셈블
13781정성태10/22/20245982오류 유형: 930. WSL + eBPF: modprobe: FATAL: Module kheaders not found in directory
13780정성태10/22/20247037Linux: 92. WSL 2 - 커널 이미지로부터 커널 함수 역어셈블
13779정성태10/22/20245609개발 환경 구성: 729. WSL 2 - Mariner VM 커널 이미지 업데이트 방법
1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...