멀티매핑은 단일 쿼리에서 여러 객체 유형을 반환할 수 있는 Dapper의 기능입니다. 이를 사용하려면 해당 개체에 데이터를 할당하는 매핑 기능을 제공하세요.
귀하의 예에서는 쿼리에서 ProductItems와 Customer를 매핑하려고 합니다.
var sql = @"select * from Product p inner join Customer c on p.CustomerId = c.CustomerId order by p.ProductName"; var data = con.Query<ProductItem, Customer, ProductItem>( sql, (productItem, customer) => { productItem.Customer = customer; return productItem; }, splitOn: "CustomerId,CustomerName" );
그러나 , 모든 고객 자산을 반환하는 데 문제가 발생했습니다. 이는 SplitOn 매개변수가 두 개체를 구분하는 열을 나타내기 때문입니다. CustomerName을 지정하지 않으면 Dapper는 결과 집합의 끝에 있다고 가정하고 null을 할당합니다.
이 문제를 해결하려면 SplitOn에서 CustomerId가 먼저 지정되고 CustomerName이 두 번째로 지정되는지 확인하세요. 그러면 결과 집합이 올바르게 분할됩니다. 그러나 테이블의 열 순서가 변경되면 고객 이름이 null이 될 수 있습니다.
참고: 결과 집합에 여러 분할 지점이 있는 경우 쉼표로 구분된 형식으로 나열하세요. . Dapper는 이러한 점을 기반으로 결과 세트를 여러 개체로 분할합니다.
위 내용은 Dapper의 멀티매핑을 올바르게 사용하여 모든 고객 속성을 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!