Golang에서 mgo 라이브러리로 ID 찾기
제공된 코드에서 다음을 사용하여 ID로 문서를 찾으려고 할 때 일반적인 문제가 발생합니다. Golang의 mgo 라이브러리. 이 오류를 이해하는 열쇠는 MongoDB의 객체 ID의 특성에 있습니다.
객체 ID 이해
MongoDB의 객체 ID는 다음을 제공하는 고유한 12바이트 16진수 값입니다. 모든 문서의 기본 키로 사용됩니다. 그러나 Golang으로 작업할 때 이러한 ID는 종종 24자의 16진수 문자열로 표시됩니다. 이는 이러한 문자열이 바이트당 2개의 16진수 숫자를 사용하여 12바이트의 개체 ID를 인코딩하기 때문입니다.
오류
오류 메시지 "ObjectID는 정확히 12바이트여야 합니다. long (got 24)"은 코드가 24자 문자열을 개체 ID로 사용하려고 시도하고 있음을 나타냅니다. 그러나 MongoDB는 24자 문자열이 나타내는 것과는 다른 12바이트 객체 ID를 기대합니다.
해결책
이 문제에 대한 해결책은 다음을 사용하는 것입니다. bson.ObjectIdHex() 함수를 사용하여 24자 16진수 문자열을 유효한 bson.ObjectId로 변환합니다. 수정된 코드는 다음과 같습니다.
<code class="go">err = coll.FindId(bson.ObjectIdHex(message.ID)).One(&result)</code>
이제 err 변수는 지정된 ID를 가진 문서가 발견되었는지 여부를 올바르게 나타냅니다.
뒤로 변환 중
bson.ObjectId가 있고 24자 16진수 표현을 가져와야 하는 시나리오에서는 ObjectId.Hex() 메서드를 사용할 수 있습니다.
추가 정보
오류 메시지에는 길이 불일치가 24바이트라고 나와 있지만 실제로는 12바이트라는 점에 유의하는 것이 중요합니다. 개체 ID의 크기가 12바이트인데 오류 메시지에는 16진수 문자열을 묶은 따옴표도 포함되어 있기 때문입니다.
위 내용은 Golang에서 mgo 라이브러리를 사용하여 ID로 문서를 찾는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!