>데이터 베이스 >MySQL 튜토리얼 >테이블 반환 매개 변수가 SQL 저장 프로시저에 대한 목록 전달을 어떻게 향상시킬 수 있습니까?

테이블 반환 매개 변수가 SQL 저장 프로시저에 대한 목록 전달을 어떻게 향상시킬 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-01 11:39:11168검색

How Can Table-Valued Parameters Improve Passing Lists to SQL Stored Procedures?

합격자 명단<> SQL 저장 프로시저에 대한 더 나은 접근 방식

자주 발생하는 것처럼 특정 데이터베이스 레코드에 여러 항목을 로드하면 문제가 발생할 수 있습니다. 웹 페이지를 통해 사용자가 보고서 항목을 선택할 수 있고 이러한 항목이 데이터베이스의 레코드(각각 보고서 및 항목 테이블)에 해당하는 시나리오를 생각해 보세요. 제출 시 선택한 항목이 ReportItems 테이블(ReportId, ItemId)에 추가되어 데이터베이스가 업데이트됩니다.

일반적으로 이를 처리하려면 SQL 명령과 저장 프로시저가 필요합니다. 그러나 SQL Server 2008에 TVP(테이블 값 매개 변수)가 도입되면서 뛰어난 솔루션이 제공되었습니다.

테이블 값 매개 변수

TVP를 사용하면 항목 목록 전달이 가능합니다. 단일 데이터세트로 저장 프로시저에 추가하므로 문자열 연결 및 반복된 매개변수 삽입이 필요하지 않습니다. 대신 TVP는 테이블 유형으로 정의되어 저장 프로시저에서 수신됩니다.

코드 구현

코드에서 AddItemsToReport 메서드를 수정하여 TVP는 다음과 같습니다.

public void AddItemsToReport(string connStr, int Id, List<int> itemList)
{
    Database db = DatabaseFactory.CreateDatabase(connStr);

    string sqlCommand = "AddItemsToReport";
    DbCommand dbCommand = db.GetStoredProcCommand(sqlCommand);

    // Create TVP DataTable
    DataTable itemTable = new DataTable("Items");
    itemTable.Columns.Add("ItemId", typeof(int));

    // Fill TVP DataTable
    foreach (int item in itemList)
        itemTable.Rows.Add(item);

    // Add TVP parameter
    db.AddParameter(dbCommand, "Items", DbType.Object, itemTable);
    db.ExecuteNonQuery(dbCommand);
}

저장된 항목에 절차:

INSERT INTO ReportItem (ReportId, ItemId)
SELECT  ReportId,
          ItemId
FROM     @Items

이점

TVP는 이전 접근 방식에 비해 여러 가지 이점을 제공합니다.

  • 코드 단순화 및 합리화
  • 매개변수 삽입을 줄여 성능 향상 오버헤드
  • 목록의 항목이 올바른 유형인지 확인하여 데이터 무결성을 향상합니다.

호환성 고려 사항

SQL Server 2008은 해당 버전 이상으로 제한됩니다. 이전 버전의 SQL Server를 다루는 경우 XML 매개변수 또는 사용자 정의 함수와 같은 대체 솔루션을 고려해야 할 수도 있습니다.

위 내용은 테이블 반환 매개 변수가 SQL 저장 프로시저에 대한 목록 전달을 어떻게 향상시킬 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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