"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 테이블 값 매개 변수는 어떻게 SQL 저장 프로 시저 성능 및 코드 단순성을 향상시킬 수 있습니까?

테이블 값 매개 변수는 어떻게 SQL 저장 프로 시저 성능 및 코드 단순성을 향상시킬 수 있습니까?

2025-02-26에 게시되었습니다
검색:212

How Can Table-Valued Parameters Improve SQL Stored Procedure Performance and Code Simplicity?

솔루션 : SQL Server 2008의 테이블 값 매개 변수

SQL Server 2008은 테이블 값 매개 변수를 도입하여 구조화 된 데이터 모음을 저장 프로 시저로 매개 변수로 전달할 수 있습니다. 이렇게하면 복잡한 문자열 조작 또는 반복 매개 변수 처리가 필요하지 않습니다.

제공된 코드에서 "additemstoreport"저장 프로 시저는 테이블 값 매개 변수를 수락하도록 업데이트 될 수 있습니다. ( @reportid int, @items as itemList- 사용자 정의 테이블 유형 )) 처럼 시작하다 reportitem (repordid, itemid)에 삽입 @reportid를 선택하고 ID @items에서 END

항목 목록에 대한 사용자 정의 테이블 유형

ALTER PROCEDURE AddItemsToReport
(
  @ReportId int,
  @Items AS ItemList -- User-defined table type
)
AS
BEGIN
  INSERT INTO ReportItem (ReportId, ItemId)
  SELECT  @ReportId,
            Id
  FROM    @Items
END

유형 생성 항목 목록으로 테이블 ( 이드 int )

C#

CREATE TYPE ItemList AS TABLE
(
  Id int
)

에서 테이블 값 매개 변수를 전달하는 C# 코드에서 사용자 정의 테이블 유형의 인스턴스를 만듭니다 :

var itemList = new itemList (); ItemList.rows.add (1); ItemList.rows.add (2); itemList.rows.add (3);

그런 다음 테이블 값 매개 변수를 저장된 절차로 전달합니다. ;
CREATE TYPE ItemList AS TABLE
(
  Id int
)

테이블 값의 이점 매개 변수

CREATE TYPE ItemList AS TABLE
(
  Id int
)

데이터베이스로의 여러 라운드 트립을 피함으로써 성능이 향상되었습니다.

    문자열 조작 또는 반복의 필요성을 제거하여 단순화 된 코드. 입력 데이터를 강력하게 입력하여.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3