합격자 명단<> 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!