>  기사  >  백엔드 개발  >  Go에서 슬라이스를 사용하여 IN 절이 있는 데이터베이스를 쿼리하는 방법은 무엇입니까?

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

DDD
DDD원래의
2024-10-26 15:44:02158검색

How to Query a Database with an IN Clause Using a Slice in Go?

Go에서 슬라이스와 함께 IN 절을 사용하여 데이터베이스 쿼리

데이터베이스 쿼리에서는 다음을 사용하여 값의 하위 집합을 기반으로 결과를 필터링하는 것이 일반적입니다. IN 절. 그러나 Go에서 정수 조각으로 작업할 때 구문적으로 유효하고 관용적인 IN 절을 생성하는 것이 어려울 수 있습니다.

조인된 두 테이블에서 고유한 제목을 검색하려고 시도하는 다음 쿼리를 고려해 보세요. IN 절은 artIds:

<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 절을 사용하는 쿼리는 성공적으로 실행됩니다.

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

이 문제에 대한 한 가지 해결책은 데이터베이스 쿼리에 대한 더 많은 제어 기능을 제공하는 sqlx 라이브러리를 사용하는 것입니다. sqlx.In 함수를 사용하면 IN 절이 포함된 쿼리를 처리하고 필요한 바인드 변수를 동적으로 생성할 수 있습니다.

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

그런 다음 결과 쿼리와 인수를 사용하여 준비된 문을 실행할 수 있습니다. sqlx.In 함수를 사용하면 쿼리가 구문적으로 유효하고 주어진 값 조각으로 효율적으로 실행될 수 있음이 보장됩니다.

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

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