>백엔드 개발 >C++ >Dapper의 멀티매핑을 올바르게 사용하여 모든 고객 속성을 검색하려면 어떻게 해야 합니까?

Dapper의 멀티매핑을 올바르게 사용하여 모든 고객 속성을 검색하려면 어떻게 해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-31 22:49:09653검색

How Can I Correctly Use Dapper's Multimapping to Retrieve All Customer Properties?

Dapper의 적절한 멀티매핑 사용법

멀티매핑은 단일 쿼리에서 여러 객체 유형을 반환할 수 있는 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: &quot;CustomerId,CustomerName&quot;
);

그러나 , 모든 고객 자산을 반환하는 데 문제가 발생했습니다. 이는 SplitOn 매개변수가 두 개체를 구분하는 열을 나타내기 때문입니다. CustomerName을 지정하지 않으면 Dapper는 결과 집합의 끝에 있다고 가정하고 null을 할당합니다.

이 문제를 해결하려면 SplitOn에서 CustomerId가 먼저 지정되고 CustomerName이 두 번째로 지정되는지 확인하세요. 그러면 결과 집합이 올바르게 분할됩니다. 그러나 테이블의 열 순서가 변경되면 고객 이름이 null이 될 수 있습니다.

참고: 결과 집합에 여러 분할 지점이 있는 경우 쉼표로 구분된 형식으로 나열하세요. . Dapper는 이러한 점을 기반으로 결과 세트를 여러 개체로 분할합니다.

위 내용은 Dapper의 멀티매핑을 올바르게 사용하여 모든 고객 속성을 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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