C#에서 SQL INSERT 후 자동 생성된 ID 검색
C#을 통해 SQL Server 테이블에 데이터를 추가할 때 자동으로 생성된 새 항목의 ID를 얻는 것은 일반적인 요구 사항입니다. 이 자습서에서는 OUTPUT
절(SQL Server 2005 이상)과 SCOPE_IDENTITY()
함수(이전 버전)를 사용하는 두 가지 방법을 보여줍니다.
방법 1: OUTPUT
절(SQL Server 2005 이상)
OUTPUT
절은 ID가 포함된 열을 지정하는 직접적인 방법을 제공합니다.
<code class="language-csharp">using (SqlCommand cmd = new SqlCommand("INSERT INTO Mem_Basic(Mem_Na,Mem_Occ) OUTPUT INSERTED.ID VALUES(@na,@occ)", con))</code>
여기서 INSERTED.ID
절의 OUTPUT
은 새로 삽입된 행의 ID를 반환합니다.
방법 2: SCOPE_IDENTITY()
함수(이전 SQL Server 버전)
이전 SQL Server 버전의 경우 SCOPE_IDENTITY()
는 현재 범위 내에서 가장 최근에 삽입된 행의 ID를 검색합니다.
<code class="language-csharp">using (SqlCommand cmd = new SqlCommand("INSERT INTO Mem_Basic(Mem_Na,Mem_Occ) VALUES(@na,@occ); SELECT SCOPE_IDENTITY();", con))</code>
이 쿼리는 데이터를 삽입한 다음 별도의 SCOPE_IDENTITY()
문에서 SELECT
을 사용하여 ID를 가져옵니다.
ID접속
두 방법 모두 ExecuteScalar()
및 유형 캐스팅을 사용하여 생성된 ID에 액세스합니다.
<code class="language-csharp">int newId = (int)cmd.ExecuteScalar();</code>
이 기술은 새로 삽입된 레코드의 ID를 효율적으로 검색하여 다양한 SQL Server 버전 간에 호환성을 제공합니다.
위 내용은 C#에서 SQL INSERT 명령 후에 삽입된 ID를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!