Dapper의 멀티매핑: SplitOn 매개변수 이해
Dapper의 멀티매핑을 사용하면 단일 쿼리에서 여러 유형을 가져올 수 있습니다. 그러나 사용자는 SplitOn 매개변수로 작업할 때 종종 문제에 직면합니다.
제공된 예에서는 연결된 Customer 클래스가 있는 ProductItem 클래스가 쿼리됩니다. 열을 올바른 개체로 분할하려고 할 때 문제가 발생합니다. 기본적으로 Dapper는 분할 지점이 Id 열이라고 가정합니다.
따라서 제공된 코드가 올바르게 작동하려면 SplitOn: "CustomerId,CustomerName"이 필요합니다. 이는 고객 개체의 시작점을 지정합니다.
그러나 기본 테이블의 열 순서가 중요하다는 점에 유의하는 것이 중요합니다. 열 순서가 변경되는 경우(예: CustomerName이 CustomerId 앞에 오는 경우), SplitOn: "CustomerId"를 사용하면 고객 이름이 null이 됩니다.
이러한 시나리오에서는 쉼표로 구분된 여러 분할 지점(예: SplitOn: "CustomerId,CustomerName")은 결과 집합을 올바르게 분할하는 데 필요합니다. 이를 통해 Dapper는 Customer 개체가 첫 번째 열에서 시작하고 두 번째 열에서 끝나는 것을 알 수 있습니다.
분할 지점의 순서는 Dapper 쿼리의 클래스 순서와 일치한다는 점을 기억하세요. Dapper에서 멀티매핑을 효과적으로 사용하려면 이 동작을 이해하는 것이 필수적입니다.
위 내용은 Dapper의 'splitOn' 매개변수는 멀티매핑 및 열 순서를 어떻게 처리합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!