찾다
백엔드 개발GolangSQLite: 메모리: 데이터베이스의 간헐적인 테이블 누락 오류

SQLite 中间歇性表丢失错误:内存:数据库

php 편집기 Banana는 SQLite의 간헐적인 테이블 손실 오류에 대한 솔루션을 제공합니다. SQLite 데이터베이스를 사용할 때 메모리 오류나 테이블 손실이 발생할 수 있습니다. 이 오류는 일반적으로 잘못된 데이터베이스 작업이나 메모리 문제로 인해 발생합니다. 이 문제를 해결하기 위해 쿼리문 최적화, 메모리 제한 증가 등과 같은 몇 가지 조치를 취할 수 있습니다. 이 문서에서는 적절한 데이터베이스 작동을 보장하기 위해 이 문제를 해결하는 방법을 자세히 설명합니다.

질문 내용

우리는 github.com/mattn/go-sqlite3 v1.14.16을 통해 Go에서 SQLite 3.39.4를 사용하고 있습니다. 연결 문자열은 ":memory:?cache=shared&mode=rwc&_mutex=no&_journal=WAL&_sync=NORMAL"

입니다.

테스트에서 "해당 테이블 없음: 구성" 오류가 가끔 표시됩니다. 혼란스러운 점은 문제의 쿼리가 테스트 사례에서 성공적으로 사용되었으며 이후 데이터베이스 연결과 오류를 발생시키는 트랜잭션 개체 모두에서 sqlite_master에 대한 쿼리에 테이블이 표시된다는 것입니다. 그러나 오류가 발생하면 쿼리가 더 이상 성공하지 않습니다.

모호한 질문인 줄 알지만, 적어도 어디를 볼지 제안해 줄 수 있는 사람이 있나요? 데이터베이스 연결은 항상 동일한 포인터 값을 갖습니다.

업데이트:

두 번째 시도에서 이 SSCCE의 문제를 거의재현할 수 있었습니다.

으아악

showTables는 SSCCE의 테이블을 표시하지 않지만 실제 테스트에서는 표시하기 때문에 실제 질문과 다릅니다. 이 예에서는 example.db 대신 :memory:를 사용하는 문제를 보여주지만 트랜잭션이 닫히지 않은 경우에만 해당됩니다. 이것이 인메모리 데이터베이스의 알려진 또는 예상된 동작입니까? :memory: 而不是 example.db 的问题,但前提是事务未关闭。这是内存数据库已知的或预期的行为吗?

解决方法

Go database/sql 隐式使用连接池,但 :memory:해결 방법Go database/sql은 암시적으로 연결 풀링을 사용하지만 :memory: 데이터베이스는 기본적으로 연결을 비공개

로 엽니다. 참고하세요:

https://www.php.cn/link/d346256ad566cf97801e5cecc45a2557

cache=shared,正如您所尝试的那样。但 SQLite 要求将其指定为 URI:file::memory:?cache=sharedfile:여러 SQLite 연결이 백그라운드에서 생성/닫기 때문에 각 문을 실행하는 연결과 데이터베이스에 대해 실제로 알 수 없으므로 당연히 일부 연결은 특정 데이터를 볼 수 있지만 다른 연결은 도착할 수 없습니다.

연결을 공유하는 한 가지 방법은

을 사용하는 것입니다.)
  • 공유 메모리 데이터베이스를 여는 보다 안정적인 방법은 다음과 같습니다. file:memdb1?mode=memory&cache=shared(命名为 memdb1
  • file:/memdb1?vfs=memdb(命名为 /memdb1,并使用 memdb)

VFS)

🎜 🎜 다른 매개변수는 불필요하거나 해로울 수도 있습니다(인메모리 데이터베이스의 경우). 🎜

위 내용은 SQLite: 메모리: 데이터베이스의 간헐적인 테이블 누락 오류의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 stackoverflow에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
Golang과 Python 사이의 선택 : 프로젝트에 적합한 올바른Golang과 Python 사이의 선택 : 프로젝트에 적합한 올바른Apr 19, 2025 am 12:21 AM

golangisidealferperperferferferferformance-criticalapplications 및 concurrentprogramming, whilepythonexcelsindatascience, 빠른 프로토 타입, 및 범위

골랑 : 동시성과 행동의 성능골랑 : 동시성과 행동의 성능Apr 19, 2025 am 12:20 AM

Golang은 Goroutine 및 Channel을 통해 효율적인 동시성을 달성합니다. 1. Goroutine은 가벼운 스레드이며 GO 키워드로 시작합니다. 2. 채널은 경주 조건을 피하기 위해 고루틴 간의 안전한 통신에 사용됩니다. 3. 사용 예제는 기본 및 고급 사용법을 보여줍니다. 4. 일반적인 오류에는 교착 상태와 데이터 경쟁이 포함되며 Gorun-Race가 감지 할 수 있습니다. 5. 성능 최적화는 채널 사용을 줄이고, 고 루틴 수를 합리적으로 설정하고, sync.pool을 사용하여 메모리를 관리하는 것을 제안합니다.

Golang vs. Python : 어떤 언어를 배워야합니까?Golang vs. Python : 어떤 언어를 배워야합니까?Apr 19, 2025 am 12:20 AM

Golang은 시스템 프로그래밍 및 높은 동시성 응용 프로그램에 더 적합한 반면 Python은 데이터 과학 및 빠른 개발에 더 적합합니다. 1) Golang은 Google에 의해 개발되어 정적으로 입력하여 단순성과 효율성을 강조하며 동시성 시나리오에 적합합니다. 2) Python은 Guidovan Rossum, 동적으로 입력, 간결한 구문, 광범위한 응용 프로그램, 초보자 및 데이터 처리에 적합합니다.

Golang vs. Python : 성능 및 확장 성Golang vs. Python : 성능 및 확장 성Apr 19, 2025 am 12:18 AM

Golang은 성능과 확장 성 측면에서 Python보다 낫습니다. 1) Golang의 컴파일 유형 특성과 효율적인 동시성 모델은 높은 동시성 시나리오에서 잘 수행합니다. 2) 해석 된 언어로서 파이썬은 천천히 실행되지만 Cython과 같은 도구를 통해 성능을 최적화 할 수 있습니다.

Golang 대 기타 언어 : 비교Golang 대 기타 언어 : 비교Apr 19, 2025 am 12:11 AM

Go Language는 동시 프로그래밍, 성능, 학습 곡선 등의 고유 한 장점을 가지고 있습니다. 1. 동시 프로그래밍은 가볍고 효율적인 Goroutine 및 채널을 통해 실현됩니다. 2. 컴파일 속도는 빠르며 작동 속도는 작동 성능이 C 언어의 성능에 가깝습니다. 3. 문법은 간결하고 학습 곡선은 매끄럽고 생태계는 풍부합니다.

Golang과 Python : 차이점을 이해합니다Golang과 Python : 차이점을 이해합니다Apr 18, 2025 am 12:21 AM

Golang과 Python의 주요 차이점은 동시성 모델, 유형 시스템, 성능 및 실행 속도입니다. 1. Golang은 동시 작업에 적합한 CSP 모델을 사용합니다. Python은 I/O 집약적 인 작업에 적합한 멀티 스레딩 및 Gil에 의존합니다. 2. Golang은 정적 유형이며 Python은 동적 유형입니다. 3. Golang 컴파일 된 언어 실행 속도는 빠르며 파이썬 해석 언어 개발은 ​​빠릅니다.

Golang vs. C : 속도 차이 평가Golang vs. C : 속도 차이 평가Apr 18, 2025 am 12:20 AM

Golang은 일반적으로 C보다 느리지 만 Golang은 동시 프로그래밍 및 개발 효율에 더 많은 장점이 있습니다. 1) Golang의 쓰레기 수집 및 동시성 모델은 높은 동시 시나리오에서 잘 수행합니다. 2) C는 수동 메모리 관리 및 하드웨어 최적화를 통해 더 높은 성능을 얻지 만 개발 복잡성이 높습니다.

Golang : 클라우드 컴퓨팅 및 DevOps의 핵심 언어Golang : 클라우드 컴퓨팅 및 DevOps의 핵심 언어Apr 18, 2025 am 12:18 AM

Golang은 클라우드 컴퓨팅 및 DevOps에서 널리 사용되며 장점은 단순성, 효율성 및 동시 프로그래밍 기능에 있습니다. 1) 클라우드 컴퓨팅에서 Golang은 Goroutine 및 채널 메커니즘을 통해 동시 요청을 효율적으로 처리합니다. 2) DevOps에서 Golang의 빠른 편집 및 크로스 플랫폼 기능이 자동화 도구의 첫 번째 선택입니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경