>  기사  >  백엔드 개발  >  Go에서 SET 변수를 사용하여 MySQL 쿼리를 실행할 수 있나요?

Go에서 SET 변수를 사용하여 MySQL 쿼리를 실행할 수 있나요?

DDD
DDD원래의
2024-10-23 18:27:02697검색

Can You Execute MySQL Queries with SET Variables in Go?

Go에서 SET 변수를 사용하는 MySQL 쿼리

Go에서는 MySQL 쿼리를 실행하기 전에 SET 변수를 활용하면 다음을 선언하여 쿼리 효율성을 높일 수 있습니다. 쿼리 자체 이전에 변수 값을 계산하고 계산을 수행합니다.

문제

SET 변수를 사용하여 쿼리를 실행하려고 하면 SELECT 문에서 구문 오류가 발생했습니다. 쿼리는 콘솔에서 완벽하게 실행되었지만 Go를 통해 실행될 때 문제가 발생했습니다. 사용자는 그러한 쿼리의 타당성에 의문을 제기하고 해결책을 찾았습니다.

해결책

이 문제는 두 가지 주요 수정 사항을 통합하여 해결되었습니다.

  1. DSN 설정: MySQL 데이터베이스에 연결하는 데 사용되는 DSN(데이터 소스 이름)에는 다음 매개변수를 포함해야 합니다.

    • multiStatements=true: 허용 단일 연결 내에서 여러 쿼리 실행.
    • interpolateParams=true: SQL 문 내에서 매개변수 보간을 활성화합니다.
  2. 데이터 정렬 변환: 데이터 정렬 불일치와 관련된 오류를 해결하기 위해 데이터베이스와 해당 테이블을 utf8mb4_0900_ai_ci에서 utf8mb4_general_ci 데이터 정렬로 변환해야 했습니다.

결론

지정된 DSN을 통합하여 매개변수를 사용하고 대조 설정의 호환성을 보장함으로써 SET 변수를 사용한 쿼리가 Go에서 성공적으로 실행되었습니다. 사용자는 매개변수를 중복하는 번거로운 접근 방식을 피하고 향상된 쿼리 효율성을 달성했습니다.

위 내용은 Go에서 SET 변수를 사용하여 MySQL 쿼리를 실행할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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