승인됨: Fortect
이러한 종류의 가이드에서는 sqlite3 오류 규정으로 이어질 수 있는 몇 가지 달성 가능한 원인을 설명한 다음 이 문제를 해결할 수 있는 방법을 제공합니다.
프레젠테이션
을 의미합니다.
대부분의 SQLite C 메인 벤트 루틴이 반환됩니다.실패와 함께 통과와 관련된 숫자 결과 코드,실패의 경우 나는 그 이유에 대한 몇 가지 아이디어를 주장할 것입니다거절. 이 문서에서는 이러한 서로 다른 유형이 각각 무엇인지 설명하려고 합니다.숫자 결과 코드는 의미합니다.
“오류 코드”는 “결과 코드”의 완전한 하위 집합입니다.문제가 발생했습니다. 대부분 오류가 없는 결과가 거의 없습니다.코드: SQLITE_ROW, sqlite_ok 및 SQLITE_DONE. 용어”오류 코드”는 이 세 가지 이외의 모든 종류의 결과 코드에 가깝습니다.
결과 암호문은 32비트 부호 있는 정수입니다.엔트리 코드의 최소 8비트는 완전한 범주를 정의합니다.결과 “기본 코드”와 연결됩니다. 더 친숙한 노래 추천새로운 오류에 대한 자세한 정보는”총 소득 코드”
주요 기사 코드는 항상 향상된 코드의 일부입니다.결과 코드. 전체 32비트 확장 코드를 사용할 때 전체 응용 프로그램검색하여 해당 기본 제품 코드를 찾을 수 없을 때 닉네임확장된 결과 코드의 최소 심각도 비트 수.
모든 막대 확장 언어도 오류 코드입니다. 따라서 조건”확장된 결과 및 코드” “확장된 알람 코드”는 상호 교환 가능합니다.
기존 호환성을 위해 인터페이스에서 반환된 C 언어미납으로 인한 기본 생산 코드.실제 마지막 오류에 대한 확장 코드는 다음과 같은 결과를 초래할 수 있습니다.일반적으로 sqlite3_extended_errcode() 인터페이스를 사용하여 얻습니다.Sqlite3_extended_result_codes() 인터페이스는 이전에 소유할 수 있습니다.그들이 어디에 두었는지 경고의 데이터베이스 연결대신 기본 결과 코드를 사용하는 코드의 확장된 결과.
모든 고유 영향 코드는 정수입니다.모든 최종 게시의 상징적 이름은 다음을 사용하여 생성됩니다.”#define” 매크로는 sqlite3.h 헤더 파일을 가져옵니다.메인 헤더 파일 sqlite3.h에는 별도의 섹션이 있습니다.코드 결과 업데이트 및 확장 프로그래밍 결과 정의.
Sim 기본 제품 코드의 물리적 이름은 “SQLITE_XXXXXX” 방식에서 가져옵니다. 여기서XXXXXX는 알파벳 대문자 메일의 시퀀스입니다. 펼친결과 코드 이름은 “SQLITE_XXXXXX_YYYYYYY” XXXXXX입니다. 여기서부분은 해당하는 기본 발생 코드이고,YYYYYYY는 결과 코드를 추가로 그룹화하는 확장입니다.
기존 결과 코드에 의한 이름과 값 번호는 고정되어 있습니다.그리고 영구적입니다. 새로운 결과 코드와 무엇보다도 새로운 확장 코드결과 쿠폰은 SQLite의 향후 버전에 나타날 수 있습니다.
결과에 대한 26가지 할인 sqlite3.h에 정의되어 있고 비용 효율적 아래 알파벳순으로 정렬:
71 종합 결과 코드 sqlite3.h에 정의되어 있으며 알파벳 순서로 아래에 유명한:
설명을 위한 것은 일반적으로 모두 102입니다.결과 코드 값은 자연스럽게 아래에 있습니다.번호순으로.
(0) SQLITE_OK
결과 코드는 SQLITE_OK이며 작업이 성공적으로 완료되고 실수가 없었다는 것. 결과가 있는 대부분의 다른 할인 코드 코드는 오류를 나타냅니다.
(1) SQLITE_ERROR
SQLITE_ERROR 결과 코드는 다음과 같은 경우에 활용되는 태그 없는 오류 코드입니다. 일반적으로 완전히 다른 오류 컴퓨터를 사용할 수 있습니다.
(2) 내부_SQLITE
SQLITE_INTERNAL 결과는 내부 법칙 실패를 나타냅니다. SQLite의 작업 버전에서 특정 응용 프로그램은 이것을 볼 수 없습니다. 표준을 종료합니다. 응용 프로그램이 이 고유한 결과 교환을 만나면 다음과 같이 표시됩니다. 일반적으로 의심할 여지 없이 웹사이트 엔진에 버그가 있습니다.
SQLite는 최근에 이 결과 지침을 생성하지 않았습니다. 애플리케이션 정의 SQL 함수 또는 가상 또는 이벤트 테이블, VFS 또는 기타 확장을 추가할 수 있습니다. 결과 코드는 계속해서 더 많이 반환되어야 합니다.
(3) SQLITE_PERM
리드 코드 SQLITE_PERM은 요청된 모드가 새로 생성된 클라이언트 기반에 대한 검색 시작점이 제공되지 않을 수 있습니다.
(4) SQLITE_ABORT
놀라운 작업이 중단된 SQLITE_ABORT 결과 코드 방식 채우기 전에 신청서가 있습니다. 참조: SQLITE_INTERRUPT.
toSqlite3_exec() 콜백이 0이 아닌 값을 반환하면 а SQLite3_exec()는 SQLITE_ABORT를 반환합니다.
특정 데이터베이스에 대한 ROLLBACK 작업이 다음과 같이 엄청나게 연결되어 있는 경우. 일어난다 찾거나 작성할 수 있으며 보류 중인 검사 또는 작성자가 실패할 수 있습니다. 일종의 SQLITE_ABORT 또는 SQLITE_ABORT_ROLLBACK 오류입니다.
이펙트 코드가 되는 것 외에, SQLITE_ABORT 값은 실제로 충돌 해결 모드로도 사용됩니다. sqlite3_vtab_on_conflict() 인터페이스에서 복원되었습니다.
(5) SQLITE_BUSY
SQLITE_BUSY 결과 컴퓨터 코드는 데이터베이스 파일 오류를 나타냅니다. 궁극적으로 혼합(또는 경우에 따라 읽음)은 진실이 동시에 활동하기 때문입니다 다른 유형의 컬렉션 연결, 일반적으로 데이터베이스 상관 관계 식별 프로세스.
예를 들어 프로세스 A가 높은 견적을 받는 트랜잭션의 중간에 있을 경우 동시에 프로세스 B는 단순히 보류 중인 쓰기 트랜잭션을 시작하려고 시도하고 있습니다. SQLite는 기본적으로 지원하기 때문에 프로세스 B는 SQLITE_BUSY 결과를 반환합니다. 달력에 작가. 프로세스 B는 프로세스 A가 완료될 때까지 기다려야 합니다. 새로운 트랜잭션을 시작하기 전에 트랜잭션. V sqlite3_ 사용자 인터페이스busy_timeout() 및 sqlite3_busy_handler() 및 pragma available busy_timeout은 B를 처리하는 신뢰할 수 있는 방법으로 B를 훨씬 덜 관리할 수 있도록 합니다. SQLITE_BUSY 오류가 있습니다.
SQLITE_BUSY 오류는 트랜잭션에서 거의 언제든지 발생할 수 있습니다. 큰 거래는 출판 또는 업데이트 시점에 처음으로 시작됩니다. 언제든지 거래가 시작됩니다. 트랜잭션 중간에 SQLITE_BUSY 오류를 방지하기 위해, 특정 특정 응용 프로그램은 완전히 즉시 시작할 수 있습니다. 사용하다 거래를 시작합니다. BEGIN IMMEDIATE 명령은 아마도 자체적으로 반환될 것입니다. SQLITE_BUSY, 그러나 성공하면 SQLite는 이것을 완전히 보장합니다. 실제 다음 COMMIT 때까지 동일한 고객과의 트랜잭션 직후 SQLITE_BUSY를 반환합니다.
SQLITE_BUSY 결과 코드가 SQLITE_LOCKED 주변에서 다릅니다. SQLITE_BUSY는 충돌이 제안함을 나타냅니다. 분리된 프로세스에서 별도의 데이터베이스로 개발, SQLITE_LOCKED 동안 일반적으로 동일한 데이터베이스 연결(또는 때때로 문서화된 캐시 데이터베이스 서비스).
(6) SQLITE_LOCKED
SQLITE_LOCKED 결과 코드는 쓰기 작업이 불가능한 위치를 보여줍니다. 위의 충돌로 인해 데이터 소스 연결이 있거나 각 공유 캐시를 사용하는 다중 데이터베이스 연결이 뒤따르는 충돌.
승인됨: Fortect
Fortect은 세계에서 가장 인기 있고 효과적인 PC 수리 도구입니다. 수백만 명의 사람들이 시스템을 빠르고 원활하며 오류 없이 실행하도록 신뢰합니다. 간단한 사용자 인터페이스와 강력한 검색 엔진을 갖춘 Fortect은 시스템 불안정 및 보안 문제부터 메모리 관리 및 성능 병목 현상에 이르기까지 광범위한 Windows 문제를 빠르게 찾아 수정합니다.
과학적 연구를 위해 DROP TABLE 문은 다른 스레드가 있는 동안 제어할 수 없습니다. 데이터베이스와의 동일한 링크에 대해 이 테이블에 의해 생성됩니다. 국을 청소하면 테이블이 전체 참가자 아래로 떨어질 수 있습니다. 리더.
SQLITE_LOCKED 결과 코드가 SQLITE_BUSY와 다릅니다. SQLITE_LOCKED는 동일한 고객 기반 연결과의 충돌을 나타냅니다. (또는 공유 캐시에 연결) 동시에 SQLITE_BUSY를 표시합니다. 하나의 다른 데이터베이스 연결과 충돌(신뢰할 수 있음) 대하다.
(7) SQLITE_NOMEM
SQLITE_NOMEM 종료 코드는 SQLite가 하나의 특정 연결을 설정할 수 없음을 나타냅니다. 이 특정 프로세스를 완료하는 데 필요한 메모리가 무엇이든 간에. 다시 말해, 그냥 핸드폰 sqlite3_malloc() 내부 또는 sqlite3_realloc() 실패 작업을 계속하기 위해 지속적으로 할당된 메모리가 필요한 완전한 경우 작업.
(8) SQLITE_READONLY
SQLITE_READONLY 결과 코드는 시도할 때마다 반환되는 것으로 설명될 수 있습니다. 최대 데이터베이스 연결을 사용할 수 없는 세부 사항 미세 조정 쓰기 권한입니다.
(9) SQLITE 인터럽트
결과 코드 SQLITE_INTERRUPT는 프로시저가 인터페이스는 sqlite3_interrupt()에 의해 중단될 수 있습니다. 참조: SQLITE_ABORT
(10) SQLITE_IOERR
결과 코드 SQLITE_IOERR은 작업에 연결된 유형을 완료할 수 없음을 나타냅니다. 현재 운영 체제에서 I/O 오류를 보고했기 때문입니다.
전체 디스크는 일반적으로 다음과 같은 SQLITE_FULL 오류를 발생시킬 가능성이 큽니다. SQLITE_IOERR의 단점.
있다
지금 이 간단한 다운로드로 컴퓨터 성능을 높이십시오. 년