방법: 문 준비 및 실행(ODBC)
문을 한 번 준비한 후 여러 번 실행하려면
SQLPrepare를 호출하여 문을 준비합니다.
필요에 따라 SQLNumParams를 호출하여 준비된 문의 매개 변수 수를 확인합니다.
필요에 따라 준비된 문의 각 매개 변수에 대해 다음 작업을 수행합니다.
SQLDescribeParam을 호출하여 매개 변수 정보를 얻습니다.
SQLBindParameter를 사용하여 각 매개 변수를 프로그램 변수에 바인딩합니다. 실행 시 데이터 매개 변수를 설정합니다.
준비된 문을 실행할 때마다 다음 작업을 수행합니다.
문에 매개 변수 표식이 있는 경우 데이터 값을 바인딩된 매개 변수 버퍼에 넣습니다.
SQLExecute를 호출하여 준비된 문을 실행합니다.
실행 시 데이터 입력 매개 변수를 사용하는 경우 SQLExecute는 SQL_NEED_DATA를 반환합니다. SQLParamData 및 SQLPutData를 사용하여 데이터를 청크로 보냅니다.
열 단위 매개 변수 바인딩을 사용하여 문을 준비하려면
SQLSetStmtAttr을 호출하여 다음 특성을 설정합니다.
SQL_ATTR_PARAMSET_SIZE를 매개 변수 집합(S) 수로 설정합니다.
SQL_ATTR_PARAM_BIND_TYPE을 SQL_PARAMETER_BIND_BY_COLUMN으로 설정합니다.
SQL_ATTR_PARAMS_PROCESSED_PTR 특성을 처리된 매개 변수 수를 보유하는 SQLUINTEGER 변수를 가리키도록 설정합니다.
SQL_ATTR_PARAMS_STATUS_PTR을 매개 변수 상태 표시를 보유하는 SQLUSSMALLINT 변수의 배열[S]을 가리키도록 설정합니다.
SQLPrepare를 호출하여 문을 준비합니다.
필요에 따라 SQLNumParams를 호출하여 준비된 문의 매개 변수 수를 확인합니다.
필요에 따라 준비된 문의 각 매개 변수에 대해 SQLDescribeParam을 호출하여 매개 변수 정보를 얻습니다.
각 매개 변수 표식에 대해 다음 작업을 수행합니다.
데이터 값을 저장할 S 매개 변수 버퍼의 배열을 할당합니다.
데이터 길이를 저장할 S 매개 변수 버퍼의 배열을 할당합니다.
SQLBindParameter를 호출하여 매개 변수 데이터 값과 데이터 길이 배열을 문 매개 변수에 바인딩합니다.
매개 변수가 실행 시 데이터 text 또는 image 매개 변수인 경우 해당 매개 변수를 설정합니다.
실행 시 데이터 매개 변수를 사용하는 경우 해당 매개 변수를 설정합니다.
준비된 문을 실행할 때마다 다음 작업을 수행합니다.
S 데이터 값과 S 데이터 길이를 바인딩된 매개 변수 배열에 넣습니다.
SQLExecute를 호출하여 준비된 문을 실행합니다.
실행 시 데이터 입력 매개 변수를 사용하는 경우 SQLExecute는 SQL_NEED_DATA를 반환합니다. SQLParamData 및 SQLPutData를 사용하여 데이터를 청크로 보냅니다.
행 단위 바인딩 매개 변수를 사용하여 문을 준비하려면
구조의 배열[S]을 할당합니다. 여기서 S는 매개 변수 집합의 수입니다. 구조에는 각 매개 변수에 대해 요소가 하나씩 포함되고 각 요소에는 두 부분이 포함됩니다.
첫 번째 부분은 매개 변수의 데이터를 보유하는 적절한 데이터 형식의 변수입니다.
두 번째 부분은 상태 표시를 보유하는 SQLINTEGER 변수입니다.
SQLSetStmtAttr을 호출하여 다음 특성을 설정합니다.
SQL_ATTR_PARAMSET_SIZE를 매개 변수 집합(S) 수로 설정합니다.
SQL_ATTR_PARAM_BIND_TYPE을 1단계에서 할당한 구조의 크기로 설정합니다.
SQL_ATTR_PARAMS_PROCESSED_PTR 특성을 처리된 매개 변수 수를 보유하는 SQLUINTEGER 변수를 가리키도록 설정합니다.
SQL_ATTR_PARAMS_STATUS_PTR을 매개 변수 상태 표시를 보유하는 SQLUSSMALLINT 변수의 배열[S]을 가리키도록 설정합니다.
SQLPrepare를 호출하여 문을 준비합니다.
각 매개 변수 표식에 대해 SQLBindParameter를 호출하여 1단계에서 할당한 구조 배열의 첫 번째 요소에 있는 해당 변수에 대한 매개 변수 데이터 값 및 데이터 길이 포인터를 가리킵니다. 매개 변수가 실행 시 데이터 매개 변수인 경우 해당 매개 변수를 설정합니다.
준비된 문을 실행할 때마다 다음 작업을 수행합니다.
바인딩된 매개 변수 버퍼 배열을 데이터 값으로 채웁니다.
SQLExecute를 호출하여 준비된 문을 실행합니다. 드라이버에서는 효율적으로 SQL 문을 각 매개 변수 집합에 대해 한 번씩 총 S번 실행합니다.
실행 시 데이터 입력 매개 변수를 사용하는 경우 SQLExecute는 SQL_NEED_DATA를 반환합니다. SQLParamData 및 SQLPutData를 사용하여 데이터를 청크로 보냅니다.