>백엔드 개발 >Golang >정수 조각을 사용할 때 IN 절이 포함된 My Go 데이터베이스 쿼리가 실패하는 이유는 무엇입니까?

정수 조각을 사용할 때 IN 절이 포함된 My Go 데이터베이스 쿼리가 실패하는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-10-25 17:22:381026검색

Why Does My Go Database Query with an IN Clause Fail When Using a Slice of Integers?

Go에서 데이터베이스 IN 절의 수수께끼

IN 절이 포함된 데이터베이스 쿼리는 공통적으로 필요하지만 Go에서의 구현으로 인해 많은 개발자가 의아해했습니다. IN 절 매개변수로 정수 조각을 사용하여 쿼리를 실행하려고 하면 일부 솔루션이 직관적이지 않게 보일 수 있습니다.

제공된 예에서 조각의 문자열 표현을 인수로 사용하면 쿼리가 실패합니다. IN 절:

<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>

그러나 이 접근 방식은 성공합니다.

<code class="go">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 (6,7)", inq)</code>

이러한 불일치의 이유는 데이터베이스/sql 패키지의 동작에 있습니다. 쿼리를 검사하지 않고 인수를 데이터베이스 드라이버에 직접 전달합니다. 따라서 쿼리의 바인드 변수(?)는 원하는 대로 여러 개의 인수가 아닌 단일 인수에 해당합니다.

<code class="go">var levels = []int{4, 6, 7}
rows, err := db.Query("SELECT * FROM users WHERE level IN (?);", levels)</code>

다행히도 sqlx 패키지는 이 문제에 대한 보다 우아한 솔루션을 제공합니다. sqlx.In을 사용하면 실행 전에 쿼리를 처리할 수 있습니다.

<code class="go">query, args, err := sqlx.In("SELECT * FROM users WHERE level IN (?);", levels)</code>

더 포괄적인 지침은 InQueries에 대한 Godoc 설명서를 참조하세요.

위 내용은 정수 조각을 사용할 때 IN 절이 포함된 My Go 데이터베이스 쿼리가 실패하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.