#title 짜잘한 문제들 [[TableOfContents]] ==== 요청한 대화 상자를 표시할 수 없습니다. (SqlMgmt) ==== 아래와 같은 메시지가 나온다. SQL Server 2012 sp1에 패치가 되었다고는 하나, 내가 관리하는 서버에는 적용이 안된듯.. sp1설치 했는데..업그레이드라 그런가?? 쩝.. 암턴.. {{{ 요청한 대화 상자를 표시할 수 없습니다. 추가 정보: 요청한 대화 상자를 표시할 수 없습니다. (SqlMgmt) Transact SQL 문 또는 일괄 처리를 실행 하는 동안 예외가 발생 했습니다. (Microsoft.SqlServer.ConnectionInfo) 사용자가이 작업을 수행할 수 있는 권한이 없습니다. (Microsoft SQL Server, 오류: 297) }}} 해결 * 해당 로그인계정에 서버역할에 sysadmin만 있어도 되는데.. 다시 만들어 주라고 하니... 그러지 말고 serveradmin 권한부여 했다가 다시 빼면 해결된다. * http://support.microsoft.com/kb/2714785/ko ==== attatch -> detach ==== 1. A서버에서 aaa 데이터베이스를 detach 했다. (로그인 중에 admin이라는 sysadmin 역할을 가진 로그인이 있다) 2. B서버에서 admin 로그인을 만들었다. 3. B서버에 attach했다. 4. 다 잘되는데.. 다이어그램에서 스키마를 선택할 수 없다. 해결.. 1. B서버에서 admin 삭제 2. B서버에서 admin 재생성.. ㅋㅋ ==== sql server configuration manager wmi 0x8007007e ==== 에러메시지 WMI공급자에 연결할 수 없습니다 . 권한이 없거나 서버에 연결할 수 없습니다. SQL Server 구성관리자에서는 SQL Server2005 서버만관리할 수 있습니다. 지정된 모듈을 찾을 수 없습니다 [0x8007007e] Cannot connect to WMI provider. You do not have permission or the server is unreachable. Note that you can only manage SQL Server 2005 and later servers with SQL Server Configuration Manager. The specified module could not be found. [0x8007007e] 해결 Copy the file: "framedyn.dll" from folder: "C:\WINDOWS\system32\wbem" TO folder: "C:\WINDOWS\system32" ==== 서로다른 MDB파일에서의 조인 ==== {{{ select A.c1, A.c2, B.cc2 from [c:\db1.mdb].Table1 A, [c:\db2.mdb].Table1 B where A.c1 = B.c1 }}} ==== 서버명 변경 ==== {{{ 1. sp_dropserver 'Old_Server_Name' 2. sp_addserver 'New_Server_Name',local 3. 서비스 재실행 select @@servername, serverproperty('servername') --두 컬럼의 값이 같아야 함 }}} ==== cannot be loaded because the execution of scripts is disabled on this system ==== {{{ File C:\connect.ps1 cannot be loaded because the execution of scripts is disabled on this system. Please see "get-help about_signing" for more details. At line:1 char:9 + ./connect <<<< 이따위 메세지를 받을 경우?? 아래와 같이 하면 되어... get-executionpolicy set-executionpolicy unrestricted get-executionpolicy }}} ==== Microsort SQL-DMO (ODBC SQLState: HY000), Expression: fcb->GetSize ()< fileSize ==== {{{ /* 문제형태 Microsort SQL-DMO (ODBC SQLState: HY000), Expression: fcb->GetSize ()< fileSize 오류 3624 Location: filemgr.cpp:1890 Expression: fcb->GetSize ()< fileSize SPID: 52 Process ID: 1168 원인: 실제 파일크기와 MDF파일에 기록된 파일크기가 달라서 나타나는 현상임.. 작업: 1. dbcc rebuild_log 후 sp_resetstatus실행후 서비스 재시작하면 자동복구하는데..복구 실패시.. 2. 모든 작업 수행(dbcc dbrecovery 수행) */ sp_configure 'allow updates', 1 reconfigure with override go update sysdatabases set status = 32768 where dbid = DB_ID('') go sp_configure 'allow updates', 0 reconfigure with override go dbcc rebuild_log('', '') go sp_dboption '', 'dbo use only', 'false' go dbcc dbrecover('') go exec sp_resetstatus ('') go dbcc checkdb('',) go }}} ==== MSSQL Server DB 주의대상 ==== {{{ --Suspect!! USE master GO EXEC sp_configure 'allow updates', 1 RECONFIGURE WITH OVERRIDE GO UPDATE master..sysdatabases SET status = 32768 WHERE name = 'act' GO UPDATE master..sysdatabases SET status = 32768 WHERE name = 'etc' GO UPDATE master..sysdatabases SET status = 32768 WHERE name = 'mat' GO UPDATE master..sysdatabases SET status = 32768 WHERE name = 'pay' GO UPDATE master..sysdatabases SET status = 32768 WHERE name = 'sal' GO USE master GO DBCC REBUILD_LOG('act','E:\PKFC\act\act_log.LDF') GO DBCC REBUILD_LOG('etc','E:\PKFC\etc\etc_log.LDF') GO DBCC REBUILD_LOG('mat','E:\PKFC\mat\mat_log.LDF') GO DBCC REBUILD_LOG('pay','E:\PKFC\pay\pay_log.LDF') GO DBCC REBUILD_LOG('sal','E:\PKFC\sal\sal_log.LDF') GO exec sp_resetstatus 'act' GO exec sp_resetstatus 'etc' GO exec sp_resetstatus 'mat' GO exec sp_resetstatus 'pay' GO exec sp_resetstatus 'sal' GO EXEC sp_configure 'allow updates', 0 RECONFIGURE WITH OVERRIDE GO DBCC CHECKDB('act') GO DBCC CHECKDB('etc') GO DBCC CHECKDB('mat') GO DBCC CHECKDB('pay') GO DBCC CHECKDB('sal') GO }}} ==== SQLDMO 문제해결 ==== {{{ 1) SQLDMO 및 관련 file들을 unregistry 후 설치 CD에서 replace 한 후 registry 등록함. step0. SQL Server를 종료함. step1. SQLDMO.dll 의 위치를 확인한 후 unregister 함. => cmd 창에서 regsvr32 /u c:\program files\microsoft sql server\80\tools\binn\sqldmo.dll 수행. step2. 기존의 SQLSMO.dll 을 rename 하고 SQL 설치 CD에서 복사하여 replace 함. step3. cmd 창에서 regsvr32 c:\program files\microsoft sql server\80\tools\binn\sqldmo.dll 수행 EM open이 성공적으로 실행이 됨. 2) EM에서 유지 관리 계획을 이용한 스케쥴 백업에 별다른 수정없이 성공적으로 실행이 됨. 3) SQL Server Personal Edition 이 설치되어 있어 SQL Server Standard Edition으로 재설치 요망. step0. 데이터베이스 일관성을 확인한 후 master와 User DB를 백업 받음. step1. 프로그램 추가/제거에서 SQL Server 삭제. step2. regedit 에서 SQL 관련 폴더 삭제. => HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Microsoft SQL Server => HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer step3. Windows 2000 재부팅 후 SQL Server Standard Edition 설치. step4. SQL Server Service 를 단일 사용자 모드로 시작. => cmd 창에서 net start mssqlserver /m => EM을 이용하여 master 데이터베이스 리스토어. => master DB에 User DB 정보가 있어 User DB 도 복원이 됨. 4) C:\inetpub\scripts 폴더를 C:\로 이동되어 있음. scripts에 TFTP 파일이 생성되어 있는것을 확인하고 nimda virus나 code red 감염으로 추정. 폴더를 삭제하려 하였으나 파일이 사용중이므로 제거가 되지 않는다는 오류 메세지 반환. IIS 서비스가 정지 되어 있는것을 확인. scripts 폴더의 등록정보 확인. 폴더 권한이 거부로 되어 있어 모든 권한 허용으로 변경. 폴더 삭제에 성공. }}} ==== Error 0x80040155, 등록되지 않은 인터페이스입니다 ==== {{{ --[MSSQL2k5]Error 0x80040155, 등록되지 않은 인터페이스입니다 regsvr32 msxml3.dll regsvr32 msxml6.dll }}} ==== 복원시 경로 바꾸는 방법 ==== {{{ ALTER DATABASE database_name SET SINGLE_USER With ROLLBACK IMMEDIATE RESTORE FILELISTONLY from Disk = 'C:\database_name.bak' restore database database_name from Disk = 'C:\database_name.bak' with recovery, move 'xERP_Data' to 'D:\database_name_Data.MDF', move 'xERP_Log' to 'D:\database_name_log.LDF' ALTER DATABASE database_name SET MULTI_USER }}} ==== 백업장치에서 테이프가 꺼내지지 않을때 ==== {{{ --백업장치 추가 USE master EXEC sp_addumpdevice 'tape', 'nexen_backup','\\.\Tape0' go backup database pubs to nexen_backup -- 내가 추가한 백업 장치명... go --장치보기 exec sp_helpdevice --백업장치 지우기 --sp_dropdevice 'nexen_backup' --열려있는 테이프 목록 보기 select * from sysopentapes --되감기를 하면 열려있던 테이프가 닫힌다. RESTORE LABELONLY FROM TAPE = '\\.\tape0' WITH REWIND }}} ==== 백업 후 백업본의 무결성 확인하기 ==== {{{ --백업본 무결성 확인 RESTORE VERIFYONLY FROM DISK = N'C:\Program Files\Microsoft SQL Server\MSSQL\BACKUP\test.bak' WITH FILE = 1 , NOUNLOAD }}} ==== 메시지 10327, 수준 14, 상태 1, 줄 1 대처방법 ==== {{{ [MSSQL2005] 메시지 10327, 수준 14, 상태 1, 줄 1 대처방법 USE Master; ALTER DATABASE AdventureWorks SET TRUSTWORTHY ON; GRANT EXTERNAL ACCESS ASSEMBLY to [Builtin\Administrators]; }}} ==== 배치파일 만들기 ==== 배치파일이란 ? 출처: http://cafe.naver.com/aquatree.cafe?iframe_url=/ArticleRead.nhn%3Farticleid=184 컴퓨터의 동작 상태를 살펴 보면 항상 사용자와의 상호작용에 의하여 작업이이루어진다는것을 알 수 있습니다. 도스라는 운영체제도 사용자가 명령을 입력하면 그 명령에 대해 도스가 분석하여 사용자가 원하는 실행 결과를 제공합니다. 따라서 사용자는 항상 도스 프롬프트 상에서 일일이 키보드를 이용한 타이핑으로 명령을 내려야 하고, 하나의 명령이 내려지면 완료될 때까지 다음 명령을 내릴수가 없습니다. 작업 과정이 얼마되지 않는다면 큰 상관이 없으나 그 과정이 매우 길고 복잡하다면 사용자는 지루함을 느끼게 됩니다. 또한 비록 짧은 작업과정이라도 컴퓨터를 켤때마다 매번 똑같은 과정을 일일이 지시하는 것도 귀찮을 것입니다. 이러한 경우 배치 파일은 가장 확실한 해결책입니다. 배치파일의 기능은 순차적이고 반복된 동일한 작업 과정을 몇개의 혹은 수십, 수백 개의 연관된 명령어를 하나의 파일로 집약하여 그 하나의 파일(배치파일)만 실행함으로써 원하는 작업 과정을 수행하는것입니다.배치파일에 붙는 확장자는 .bat(batch 의 약어) 입니다.도스에서 실행이 가능하기 때문에 .com, .exe 확장자가 붙는 외부 명령어와 함께 실행 가능한 파일로 분류됩니다.차이가 있다면 .com, .exe 명령어는 컴퓨터만 해석 가능한 기계어 코드로 구성되어 있는반면, 배치 파일은 사람이 알아볼수 있는 일반 텍스트로 이루어져있다는 것입니다. 그래서 사용자들은 문서작성에 이용하는 워드프로세서나 텍스트에디터 등을 이용해 배치 파일을 작성할 수 있습니다. 그러나 워드프로세서는 덩치가 크고 원래 목적이 편집과 출력을 위해 만들어진 것이므로 단순한 배치 파일을 작성하는 데는 권하고 싶지 않습니다. 저장할때도 워드프로세서 고유의 포맷(예" .hwp 확장자를 가지는 아래아한글 데이터 파일)으로 저장하면 인식이 되지 않으므로 아스키 파일로 저장해야 합니다.가장 편리한 방법은 일반 문서 에디터( 도스의 Edit, Q에디터,U에디터 등)를 이용하거나 도스의 'Copy Con' 명령으로 배치 파일을 만드는 것입니다.다음과 같이 'Copy con 파일명' 형식으로 입력하고 엔터를 누르면 도스 프롬프트 상태에서 편집할 수 있는 상태가 됩니다. ------------------------------- C:\Bats> copy con Timedate.bat cls time date ^Z 1 File(s) copied ------------------------------- 여기서 쓰고 싶은 대로 적기만 하면 됩니다.제일 마지막행의 ^Z 는 파일의 제일 마지막 부분이라는 것을 도스에게 알려주는 코드로 < Ctrl + Z > 키 또는 F6 키를 누르면 됩니다. 그리고 엔터키를 한번더 누르면 '1 File(s) copied' 라는 메세지가 출력되는데, 이는 방금 ' copy con 파일명 ' 으로 작성된 문서파일이 성공적으로 만들어졌다는 뜻입니다.위의 문서파일은 확장자가 .BAT 로 붙었기 때문에 실행가능한 외부 명령어가 되는데, 배치파일은 명령이 기록되어 있는 순서대로 실행되기 때문에 timedate.bat 를 실행시키면 먼저 화면을 지우고 난뒤 시스템의 시간과 날짜를 설정합니다.간단한 배치파일은 'copy con 파일명' 으로 작성하는 것이 다른 프로그램의 도움없이 쉽고 빠르게 처리할 수 있습니다. 하지만 배치파일이 조금 길거나 작성중에 수시로 편집할 일이 생기는 경우에는 불가능합니다. 'copy con 파일명' 으로 파일을 작성하면 행으로 다시돌아갈 수 없을 ?아니라 수정이 불가능하기 때문입니다. 그러므로 배치파일을 만들 필요가 있을때는 문서 에디터를 이용하는 것이 좋습니다. ▶ 배치파일 작성 명령어 9인방 배치 파일은 파일 안에 기록되어 있는 명령의 순서대로 실행됩니다.가장 대표적인 것이 부팅에 이용되며, 컴퓨터의 루트 디렉토리에 위치하고 있는 Autoexec.bat 파일입니다. 그런데 만약 배치 파일의 실행의 순서를 순차적이 아닌멀티부팅용 Autoexec.bat 처럼 사용자 마음대로 정하고 싶다면 배치파일에 제공되는배치명령어의 용도를 알고 있어야 합니다. 1. CALL 현재 실행중인 배치 파일을 종료하지 않고 필요한 다른 배치파일을 호출하여 실행한 다음 원래의 배치파일로 다시 돌아오려고 할 때 사용됩니다. ◇ 사용법 : Call [drive:]\[경로]\<배치파일명>[.BAT] ◇ 예 : Call c:\bats\sample.bat 어떤 배치 파일을 실행하는 도중에 경로 C:\bats 에 있는 sample.bat 파일을 실행한 다음 다시 원래의 배치파일로 돌아옵니다. 2. CHOICE 배치 프로그램 내에서 사용자의 선택을 묻기 위해 사용됩니다. 배치 파일 제작자가 설정한 물음을 출력하면서 지정된 키 입력을 기다립니다. 이 명령은 배치파일 내에서만 사용 가능합니다. ◇ 사용법 :choice [/C[:]문자열][/N][/S][/T[:]기본키,대기시간][메세지] ◇ 옵션 - /C[:]문자열 : 사용자가 선택할 수 있는 키목록을 [] 괄호 내에 ', ' 로 구분하여 출력하고 /C 스위치를 사용하지 않으면 기본적으로 YN이 사용됩니다. - /N : 프롬프트를 출력하지 않도록 합니다. - /S : 사용자의 입력에서 소문자, 대문자를 구분하도록 합니다. - /T[:]기본키, 대기시간 : 기본키를 지정한 후 대기시간 동안 사용자의 키 입력이 없으면 자동적으로 기본키가 입력된 것으로 간주하고 진행됩니다. 지정 가능한 대기시간은 초단위이며 0에서 99 사이의 값입니다. - 메세지 : 화면에 출력될 메세지를 지정합니다. ◇ 예 : choice /c:abCD /s /t : C, 5 다음중에서 하나를 선택하십시오 a, b, C, D ◇ 설명 : 입력 가능한 키를 a,b,C,D로 한정하며 사용자로부터 입력되는 영문자의 대,소문자를 구분하는데, 만약 5초 내에 사용자로부터 키 입력이 없다면 C 가 입력된 것으로 간주합니다. 그리고 화면에는 '다음중에서 하나를 선택하십시오 a, b, C, D[a,b,C,D]? ' 라는 메세지가 출력됩니다. 3. ECHO 배치파일 실행중에 명령어를 화면에 표시할 것인지의 여부를 설정하며, 그 상태를 표시합니다. 한편 ECHO 명령 뒤에 오는 메세지는 화면에 나타납니다. ◇ 사용법 : echo [on/off] [문자열] ◇ 옵션 - on : 배치 파일 실행중에 그 배치 파일 내의 명령어를 화면에 표시합니다. - off : 배치 파일 실행중에 명령어를 화면에 출력하지 않도록 합니다. - 문자열 : 화면에 출력하고 싶은 메세지를 적어줍니다. - 없음 : 현재 ECHO 설정 상태를 표시합니다. ◇ 예 : echo off ☞ 현재 실행중인 배치 파일 내의 명령어를 화면에 나타나지 않도록 함. echo echo 안녕하세요?~ ☞ 현재 echo 설정상태를 표시하며 안녕하세요?~ 라는 문구를 화면에 출력합니다. 4. FOR 지정된 집합 중의 각각의 요소에 대하여 명령으로 설정한 처리를 반복 실행합니다. ◇ 사용법 For %%<변수> IN (<집합>) DO <명령> [<옵션>] ☞ 배치파일용. For %<변수> IN (<집합>) DO <명령> <옵션>] ☞ 순차처리용. ◇ 옵션 - %%<변수>, &<변수> : 변수로 사용되는 것은 임의의 영문자로 1자만 허용됩니다. 주의할 점은 배치파일에서 사용할 경우는 반드시 %%처럼 두개를 연달아 사용해야 하며, 일반 도스 프롬프트에서 사용할 때는 % 하나만 사용합니다. - <집합> : %%<변수>에 대입하고 싶은 값을, 또는 스페이스로 구분하여 대입하고 싶은 순서대로 나열합니다. - <명령> : %%<변수>에 대입되어 있는 값에대해 반복적으로 실행하고 싶은 명령을 지정합니다. - <옵션> : 지정한 명령의 옵션이나 FOR 명령에서 지정한 옵션을 설정합니다. ◇ 예 for %%f in (bak tmp $$$) do del *.%%f /p ☞ 배치파일의 경우 for %d in (read,wh,file) do hlist %d*.* ☞ 도스 프롬프트에서 실행시 ◇ 설명 : 첫 번째는 bak, tmp, $$$ 를 순서대로 %%f 환경 변수에 대입하여 차례대로 DEL *.bak /p, DEL *.tmp /p, DEL *.$$$ .p 를 실행한 것과 동일한 결과를 얻게됨. 두번째는 READ,WH,FILE 를 순서대로 %d 환경변수에 대입하여 차례대로 HLIST READ*.*, HLIS TWH *.* , HLIST FILE *.* 를 실행한 것과 동일한 결과를 얻게 됩니다. 5. GOTO 배치 처리의 흐름을 <레이블>에서 정의되어 있는 위치로 옮깁니다. ◇ 사용법 :Goto <레이블> ◇ 예 : goto loop :loop 각종 처리할 내용 ◇ 설명 : 레이블 loop 로 배치 처리의 제어권을 이동시켜 loop 항목에 지정된 각종 처리할 내용을 실행시킵니다. ◇ 참고 : 배치 파일에 레이블 표시는 레이블명 앞에 콜론(:) 을 붙여주며 줄을 바꿔 맨 앞에 지정해 주어야 합니다. 6. IF 지정한 조건의 판단 결과에 따라서 배치 처리를 진행합니다. ◇ 사용법 : If [NOT] <조건> <명령> ◇ 옵션 - NOT : 지정한 조건의 반대 조건일 때만 실행합니다. - 조건 - ERRORLEVEL <수치> : 바로 전에 실행한 명령(프로그램)의 종료 코드가 <수치> 이상일 때에는 참이 되고 <명령> 이 실행됨. - <문자열1> == <문자열2> : <문자열1> 과 <문자열2> 가 같을 때에만 참이되고 <명령>이 실행됩니다. 주의할 점은 문자열의 대,소문자가 구별되며, 문자열중에 구분기호(콤마,스페이스,세미콜론,등호,탭)가 포함되어 있으면 않됩니다. - EXIST <파일명> : <파일명>으로 지정한 파일(경로포함)이 존재할 때에만 참이 되고 <명령>이 실행됩니다. <파일명>에는 와일드카드 문자의 사용이 가능합니다. ◇ 예 : if errorlevel 2 goto quit if not %1 ==%2 goto process if exist d:\work\temp.$$$ del d:\work\temp.$$$ ◇ 설명 : 직전에 실행한 명령의 종료 코드가 2 이상일 경우 레이블 QUIT로 이동합니다. 환경변수 %1과 환경변수 %2에 대입되어 있는 문자열이 같지 않을 경우에만 레이블 PROCESS 로 이동합니다. 경로 D:\Work 에 temp.$$$ 라는 파일이 존재하면 그 파일을 삭제합니다. 7. PAUSE 배치 파일 실행을 일시 정지합니다. ◇ 사용법 :Pause [문자열] ◇ 옵션 - 문자열 : 문자열을 생략하면 'press any key to continue...'라는 메세지가 화면에 출력됩니다. 만약 PAUSE 명령 뒤에 어떤 메세지를 지정하여 그 메시지를 출력하고 싶다면 'Echo On' 명령을 우선 내려야 합니다. ◇ 예 : echo on pause 준비가 되었으면 아무키나 누르세요... ◇ 설명 : 배치 처리 중 pause명령을 만났을때 임의의 다른 메시지를 화면에 출력하고 싶다면 예 에서와 같이 반드시 echo on 명령이 선행되어야 하며 예의 경우에는 ' 준비가 되었으면 아무키나 누르세요...' 라는 메세지가 출력됩니다. ◇ 참고 : 위 처럼 하면 화면에 Pause 라는 명령어까지 같이 출력되므로 이런경우 echo on echo 준비가 되었으면 아무키나 누르세요... pause > Null 이런식으로 사용하면 출력하고자 하는 메세지만 화면에 출력됩니다. 8. REM 배치 파일 내에 주석문을 부여하고 싶을 때 사용합니다. ◇ 사용법 :rem [문자열] ◇ 옵션 - 문자열 : 주석문으로 쓰고 싶은 것을 적어줍니다. ◇ 예 : REM 이 배치파일은 샘플입니다. 배치파일내의 적당한 위치에 적절한 주석문을 붙여두면 배치 처리의 흐름을 일목요연하게 볼 수 있습니다. 9. SHIFT 배치 파일에 주어진 파라미터(%1~%9)와 실행시에 지정되는 값과의 대응을 하나씩 뒤로 이동하여 표시합니다. ◇ 예 :loop if "%1" == " " goto end echo %0 %1 %2 %3 %4 %5 %6 %7 %8 %9 shift goto loop :end 위와 같이 배치 파일을 작성해두고 다음과 같이 배치파일을 실행해 보면 shift 명령이 어떤 역할을 하는지 금방 알 수 있습니다.. C:\bats> test.bat A B C D E F G H I J 0 1 2 3 4 5 ☜똑같이 입력하고 실행후 확인 ==== 기타 링크 자료 ==== * [http://support.microsoft.com/kb/240872/ SQL Server를 실행하는 서버 사이에서 데이터베이스를 이동할 때 사용 권한 문제를 해결하는 방법] * [http://support.microsoft.com/gp/errormessage MS제품 오류메시지 검색] * [http://support.microsoft.com/kb/832017 Windows 서버 시스템의 서비스 개요 및 네트워크 포트 요구 사항] * attachment:짜잘한문제들/터미널_session으로_인한_접속불능시.pdf