Sqlite3을 사용하여 Go에서 "Database is Locked" 오류 이해
Go에서 SQLite3 데이터베이스로 작업할 때 "database is locked" 오류가 발생합니다. " 오류는 당혹스러운 경험이 될 수 있습니다. 이 오류는 일반적으로 여러 스레드가 동일한 데이터베이스 파일에 동시에 액세스하려고 할 때 발생합니다. 그러나 프로그램에서 하나의 연결만 얻는다고 언급했다는 점은 주목할 가치가 있습니다.
문제를 자세히 조사한 결과 모든 쿼리 결과를 닫았음에도 불구하고 데이터베이스 파일의 핸들이 여러 개 생성되었다는 사실을 올바르게 식별하셨습니다. 이는 Opendfileview 프로그램을 사용하여 확인할 수 있습니다. 이 문제를 해결하려면 제공된 코드를 분석하고 문제가 있는 위치를 식별해 보겠습니다.
getDatabaseHandle 함수는 SQLite3 데이터베이스에 대한 연결을 초기화하고 트랜잭션을 시작합니다. 생성된 데이터베이스 핸들과 트랜잭션에 대한 포인터를 반환합니다. dosomething 함수 내에서 데이터베이스에 대한 쿼리를 실행한 다음 결과 행을 닫습니다. 그런 다음 트랜잭션 내에서 몇 가지 삽입 쿼리를 수행하여 최종적으로 커밋합니다.
코드를 조사해 보면rows.Close() 호출이 지연되지 않는 것을 알 수 있습니다. 이로 인해 결과 행이 열린 상태로 남아 추가 데이터베이스 핸들이 생성될 수 있습니다. 아래와 같이 행 닫기를 연기해 보세요.
if err != nil { return err } defer rows.Close() if rows.Next() { ... }
행 닫기를 연기하면 오류가 발생하더라도 결과 행이 닫히도록 할 수 있습니다. 이렇게 하면 연결된 데이터베이스 핸들을 해제하고 "데이터베이스가 잠겼습니다" 오류를 방지하는 데 도움이 됩니다.
위 내용은 연결이 하나만 있어도 내 Go 프로그램이 SQLite3에서 '데이터베이스가 잠겼습니다' 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!