원래 주소: http://www.51la.org/webjx/htmldata/2005-12-24/1135405777.html
Abstract 저장 프로시저 호출은 b/s 시스템에서 일반적으로 사용됩니다. 기존의 호출 방식은 속도가 느릴 뿐만 아니라, 저장 프로시저 수가 늘어남에 따라 코드도 계속 확장되어 유지 관리가 어렵습니다. 새로운 방법은 이러한 문제를 어느 정도 해결합니다.
키워드 asp.net; 저장 프로시저 .net을 사용하는 과정에서 데이터베이스 액세스는 매우 중요한 부분이며, 특히 b/s 시스템 구축 과정에서는 데이터베이스 작업이 거의 필수 작업이 되었습니다. 데이터베이스 작업을 구현하기 위해 저장 프로시저를 호출하는 것은 많은 프로그래머가 사용하는 방법이며, 대부분의 프로그래머는 가능한 경우 저장 프로시저를 사용하고 SQL 문을 직접 사용하는 경우는 거의 없으므로 저장 프로시저는 매우 유용하고 중요합니다.
저장 프로시저 소개
간단히 말해서 저장 프로시저는 일부 SQL 문과 제어 문으로 구성된 캡슐화된 프로시저이며 데이터베이스에 상주하며 클라이언트 응용 프로그램이나 다른 프로시저 또는 트리거에서 호출할 수 있습니다. 해당 매개변수를 전달하고 반환할 수 있습니다. 애플리케이션의 함수 프로시저와 마찬가지로 저장 프로시저도 이름으로 호출할 수 있으며 입력 및 출력 매개변수도 있습니다.
다양한 반환 값 유형에 따라 저장 프로시저를 레코드 세트를 반환하는 저장 프로시저, 숫자 값을 반환하는 저장 프로시저(스칼라 저장 프로시저라고도 함), 동작 저장 프로시저의 세 가지 범주로 나눌 수 있습니다. 이름에서 알 수 있듯이 레코드 세트를 반환하는 저장 프로시저의 실행 결과는 데이터베이스에서 하나 이상의 조건을 충족하는 레코드를 검색하는 것입니다. 예를 들어 데이터베이스에서 실행 후 반환 값이 있는 함수 또는 명령을 실행합니다. 마지막으로 동작 저장 프로시저는 데이터베이스에서 업데이트 및 삭제 작업과 같이 반환 값 없이 데이터베이스의 특정 기능을 구현하는 데만 사용됩니다. .
저장 프로시저 사용의 이점
SQL 문을 직접 사용하는 것과 비교할 때 응용 프로그램에서 저장 프로시저를 직접 호출하면 다음과 같은 이점이 있습니다.
(1) 네트워크 트래픽이 줄어듭니다. 행 수가 적은 저장 프로시저를 호출하는 것과 SQL 문을 직접 호출하는 것 사이에는 네트워크 트래픽에 큰 차이가 없을 수 있습니다. 그러나 저장 프로시저에 수백 개의 SQL 문이 포함되어 있으면 SQL 문을 하나씩 호출하는 것보다 확실히 성능이 좋습니다. 하나. 훨씬 더 높다.
(2) 실행 속도가 빨라집니다. 두 가지 이유가 있습니다. 첫째, 저장 프로시저가 생성될 때 데이터베이스가 이미 한 번 구문 분석하고 최적화했습니다. 둘째, 저장 프로시저가 실행되면 저장 프로시저의 복사본이 메모리에 유지되므로 다음에 동일한 저장 프로시저가 실행될 때 메모리에서 직접 호출할 수 있습니다.
(3) 더 강력한 적응성: 저장 프로시저가 저장 프로시저를 통해 데이터베이스에 액세스하므로 데이터베이스 개발자는 저장 프로시저 인터페이스를 변경하지 않고도 데이터베이스를 변경할 수 있으며 이러한 변경은 데이터베이스에 영향을 미치지 않습니다.
(4) 분산 작업: 애플리케이션과 데이터베이스의 코딩 작업이 서로 억압되지 않고 독립적으로 수행될 수 있습니다.
위의 분석을 통해 애플리케이션에서 저장 프로시저를 사용해야 한다는 것을 알 수 있습니다.
저장 프로시저를 호출하는 두 가지 다른 방법
새로운 방법의 장점을 강조하기 위해 먼저 .net에서 저장 프로시저를 호출하는 "공식적인" 방법을 소개하겠습니다. 또한 이 기사의 모든 샘플 프로그램은 sqlserver 데이터베이스에서 작동합니다. 다른 상황도 유사하므로 앞으로는 하나씩 설명하지 않겠습니다. 이 문서의 모든 예제는 C# 언어로 작성되었습니다.
애플리케이션에서 데이터베이스에 액세스하기 위한 일반적인 단계는 다음과 같습니다. 먼저 데이터베이스 연결 sqlconnection을 선언한 다음 데이터베이스 명령 sqlcommand를 선언하여 sql 문과 저장 프로시저를 실행합니다. 이 두 개체를 사용하면 서로 다른 실행 방법을 사용하여 필요에 따라 목표를 달성할 수 있습니다. 추가해야 할 것은 system.data.sqlclient를 사용하여 페이지에 다음 참조 문을 추가하는 것을 잊지 마세요.
저장 프로시저 실행과 관련하여 첫 번째 유형의 저장 프로시저가 실행되면 데이터 어댑터를 사용하여 결과를 데이터 세트에 채운 다음 데이터 그리드 컨트롤을 사용하여 결과를 페이지에 표시할 수 있습니다. 실행된 경우 두 번째, 세 번째 저장 프로시저인 경우에는 이 프로시저가 필요하지 않으며 특정 반환을 기준으로 작업이 성공적으로 완료되었는지 확인하기만 하면 됩니다.
(1) 매개변수 없이 저장 프로시저를 실행하는 코드는 다음과 같습니다.
sqlconnection conn=new sqlconnection("connectionstring");
sqldataadapter da = 새로운 sqldataadapter();
da.selectcommand = 새로운 sqlcommand();
da.selectcommand.connection = 연결;
da.selectcommand.commandtext = "프로시저 이름";
da.selectcommand.commandtype = commandtype.storedprocedure;
그런 다음 여기에서 다양한 목적으로 프로세스를 수행하는 적절한 방법을 선택하십시오.
(2) 매개변수를 사용하여 저장 프로시저를 실행하는 코드는 다음과 같습니다(저장 프로시저를 호출하는 함수를 exeprocedure(string inputdate)로 선언할 수 있음).
sqlconnection conn=new sqlconnection("connectionstring");
sqldataadapter da = 새로운 sqldataadapter();
da.selectcommand = 새로운 sqlcommand();
da.selectcommand.connection = 연결;
da.selectcommand.commandtext = "프로시저 이름";
da.selectcommand.commandtype = commandtype.storedprocedure;
(위 코드는 동일하며, 추가할 코드는 다음과 같습니다)
param = new sqlparameter("@parametername", sqldbtype.datetime);
param.direction = 매개변수 방향.input;
param.value = Convert.todatetime(inputdate);
da.selectcommand.parameters.add(param);
그러면 입력 매개변수가 추가됩니다. 출력 매개변수를 추가해야 하는 경우:
param = new sqlparameter("@parametername", sqldbtype.datetime);
param.direction = 매개변수 방향.output;
param.value = Convert.todatetime(inputdate);
da.selectcommand.parameters.add(param);
매개변수 저장 프로시저의 반환 값을 얻으려면 다음을 수행하십시오.
param = new sqlparameter("@parametername", sqldbtype.datetime);
param.direction = 매개변수 방향.returnvalue;
param.value = Convert.todatetime(inputdate);
da.selectcommand.parameters.add(param);
위의 코드에서 우리는 저장 프로시저가 많거나 저장 프로시저에 매개 변수가 많을 때 이 방법이 개발 속도에 큰 영향을 미치는 반면, 프로젝트가 상대적으로 크다면 이러한 기능을 수행한다는 것을 알 수 있습니다. 데이터베이스 로직은 향후 유지 관리에도 큰 부담이 될 것입니다. 그렇다면 이 문제를 해결하는 개선된 방법이 있습니까? 매개변수 없이 저장 프로시저를 실행할 때 저장 프로시저의 이름만 전달하면 해당 저장 프로시저를 호출할 수 있다고 생각했는데, sqlserver 데이터베이스에서는 "저장 프로시저 이름(매개변수 목록)"을 직접 입력하면 되는 것이었습니다. "를 쿼리 분석기에서 실행합니다. 이러한 문자열을 사용하여 저장 프로시저를 실행할 수 있습니다. 그렇다면 이 아이디어를 응용 프로그램에 적용할 수 있을까요?
따라서 컴파일러에 해당 코드를 입력하십시오. 이러한 코드는 매개 변수 없이 저장 프로시저를 호출하는 코드를 기반으로 수정됩니다. 구체적인 코드는 다음과 같습니다.
sqlconnection conn=new sqlconnection("connectionstring");
sqldataadapter da = 새로운 sqldataadapter();
da.selectcommand = 새로운 sqlcommand();
da.selectcommand.connection = 연결;
da.selectcommand.commandtext = "프로시저 이름('para1','para2',para3)";
da.selectcommand.commandtype = commandtype.storedprocedure;
코드의 대표성을 높이기 위해 호출할 저장프로시저의 첫 번째와 두 번째 매개변수는 문자열형, 세 번째 매개변수는 정수형으로 한다. 실행 후 예상한 결과를 얻을 수 있음을 확인했습니다!
두 가지 호출 방법 비교 비교를 통해 두 번째 방법에는 개발 속도를 높이고 개발 시간을 절약할 수 있으며 코드 유지 관리가 쉽고 시스템 크기도 줄일 수 있다는 분명한 이점이 있음을 알 수 있습니다. 어느 정도. 그러나 저장 프로시저 매개 변수 처리는 비교적 일반적이므로 출력 매개 변수를 얻거나 저장 프로시저의 반환 값을 얻으려는 경우 이 방법은 요구 사항을 충족할 수 없습니다. 그럼에도 불구하고 이 방법을 사용하면 개발자는 코드의 상당 부분을 저장할 수 있습니다. 출력 매개변수와 반환 값을 가져올 필요가 없다면 거의 "한 번에" 수행할 수 있습니다. 따라서 실제 프로그램 개발에서 이 방법은 여전히 실용적인 가치를 갖고 있습니다.