Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

SQL 서버 - The transaction log for database '...' is full due to 'LOG_BACKUP'.

.ldf 파일의 사이즈가 너무 커져서 하드 디스크 용량 부족으로 SQL 쿼리 실행시 오류가 발생했습니다.

The transaction log for database '...' is full due to 'LOG_BACKUP'
  Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code. 

 Exception Details: System.Data.SqlClient.SqlException: The transaction log for database '...' is full due to 'LOG_BACKUP'. 

Source Error: 

Line 277:                command.Parameters.Add(new SqlParameter("@Name", nameText));
Line 278:                command.Parameters.Add(new SqlParameter("@Password", Guid.NewGuid().ToString()));
Line 279:                int affected = command.ExecuteNonQuery();
Line 280:
Line 281:                command.Parameters.Clear();
  

 Source File:  d:\UnitTest\Net20Test\Default.aspx.cs    Line:  279 

Stack Trace: 

[SqlException (0x80131904): The transaction log for database '...' is full due to 'LOG_BACKUP'. ]
   System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection) +117
   System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection) +87
   ...[생략]...
   System.Data.SqlClient.SqlCommand.ExecuteNonQuery() +323
   Net20Test._Default.Page_Load(Object sender, EventArgs e) in d:\UnitTest\Net20Test\Default.aspx.cs:279
   ...[생략]...
   System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +3418

부하테스트 용이라서 ldf 파일을 보관할 필요가 없으므로 SSMS를 띄워 "Maintenance Plans"에 로그 파일을 줄이는 명령을 스케줄링으로 등록해 두었습니다.

ssms_query_error_1.png

USE my_test_db_78f5aac8-e0a6-44ef-be4b-f2d158fb61b9
GO

ALTER DATABASE my_test_db_78f5aac8-e0a6-44ef-be4b-f2d158fb61b9
SET RECOVERY SIMPLE;
GO

DBCC SHRINKFILE (my_test_db_78f5aac8-e0a6-44ef-be4b-f2d158fb61b9_log, 7);
GO

ALTER DATABASE my_test_db_78f5aac8-e0a6-44ef-be4b-f2d158fb61b9
SET RECOVERY FULL;
GO

그런데 이 쿼리를 실행하면서 오류가 발생하는 것입니다.

Msg 911, Level 16, State 1, Line 1
Database 'my_test_db_78f5aac8' does not exist. Make sure that the name is entered correctly.
Msg 102, Level 15, State 1, Line 3
Incorrect syntax near '-'.

아하... DB 쿼리에 "-" 문자를 쓸 수 없는 것입니다. 그래서 이런 경우 겹따옴표를 붙여줘야 합니다.

USE "my_test_db_78f5aac8-e0a6-44ef-be4b-f2d158fb61b9"
GO

ALTER DATABASE "my_test_db_78f5aac8-e0a6-44ef-be4b-f2d158fb61b9"
SET RECOVERY SIMPLE;
GO

DBCC SHRINKFILE ("my_test_db_78f5aac8-e0a6-44ef-be4b-f2d158fb61b9_log", 7);
GO

ALTER DATABASE "my_test_db_78f5aac8-e0a6-44ef-be4b-f2d158fb61b9"
SET RECOVERY FULL;
GO




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 11/5/2013]

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

비밀번호

댓글 작성자
 




... 196  [197] 
NoWriterDateCnt.TitleFile(s)
16정성태7/17/200319764COM 개체 관련: 3. IE 툴밴드의 위치문제파일 다운로드1
15정성태7/17/200320773VC++: 5. 시행착오 - 클래스 포인터를 void * 로 대입후 delete 하는 경우.
14정성태7/17/200322304VC++: 4. MFC Message 처리 구조
13정성태7/17/200322066VC++: 3. template 활용의 최고 단계!
12정성태5/7/200619625VC++: 2. void func1( MYCLASS *&pBuildingElement ); 선언의 의미
10정성태7/17/200317973기타: 2. 데브피아 사이트의 클럽 서비스 내에 있는 Standard C++ Research
9정성태7/17/200323543기타: 1. Programming Applications for Microsoft Windows 4th Edition
8정성태7/17/200320937COM 개체 관련: 2. CWindowImpl 의 기본 윈도우 클래스 명을 바꾸려면?
7정성태7/17/200323514VS.NET IDE: 1. VC++ 프로파일링 사용법
4정성태7/17/200335889VC++: 1. C++ 클래스 멤버변수 초기화 [3]
3정성태7/17/200321860스크립트: 2. JScript에서의 Blocking 동작을 막아주는 COM 메서드
2정성태6/14/200640642COM 개체 관련: 1. IWebBrowser2와 IHTMLDocument2의 상호 변환 [2]
1정성태7/17/200324806스크립트: 1. IE 의 훌륭한 저장기능 - userData
... 196  [197]