IN 절의 슬라이스를 사용하여 Go 데이터베이스 쿼리를 실행하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-10-25 21:11:28
원래의
493명이 탐색했습니다.

How to Execute a Go Database Query with a Slice in the IN Clause?

Slice IN 절을 사용한 Golang 데이터베이스 쿼리: 포괄적인 이해

질문:

다음 Golang 데이터베이스 쿼리는 왜 수행됩니까? IN 절에서 int 조각을 사용하면 실패합니다:

<code class="go">inq := "6,7" //strings.Join(artIds, ",")
rows, err = db.Query("SELECT DISTINCT title FROM tags_for_articles LEFT JOIN tags ON tags.id = tags_for_articles.tag_id WHERE article_id IN (?)", inq)</code>
로그인 후 복사

답변:

질의에 사용되는 데이터베이스/sql 패키지가 쿼리하고 인수를 데이터베이스 드라이버에 직접 전달합니다. 이로 인해 가변 개수의 인수가 포함된 IN 절이 포함된 쿼리를 처리하는 것이 어려워집니다.

제공된 쿼리에서 ? 바인드 변수는 단일 인수에 해당하는 반면, 의도된 용도는 슬라이스 artId의 길이에 따라 여러 인수를 바인딩하는 것입니다. 그러나 드라이버는 이를 올바르게 처리할 수 없습니다.

이 문제를 해결하려면 데이터베이스 쿼리에 대한 더 강력한 제어 기능을 제공하는 sqlx 패키지를 사용하는 것이 좋습니다.

사용하는 솔루션 sqlx 패키지:

<code class="go">var artIds = []int{6, 7}
query, args, err := sqlx.In("SELECT DISTINCT title FROM tags_for_articles LEFT JOIN tags ON tags.id = tags_for_articles.tag_id WHERE article_id IN (?);", artIds)</code>
로그인 후 복사

sqlx.In 함수는 쿼리를 처리하고 int 조각에 대한 적절한 바인드 변수를 생성하여 쿼리가 성공적으로 실행될 수 있도록 합니다.

이 주제에 대한 자세한 내용은 InQueries에 대한 Godoc 설명서를 참조하세요.

위 내용은 IN 절의 슬라이스를 사용하여 Go 데이터베이스 쿼리를 실행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿