솔루션 : 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