질문:
다음 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!