문 준비 및 실행(ODBC)
적용 대상: SQL Server Azure SQL 데이터베이스 Azure SQL Managed Instance Azure Synapse Analytics Analytics Platform System(PDW)
문을 한 번 준비한 다음 여러 번 실행하려면
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 설정합니다.
처리된 매개 변수 수를 보유하도록 SQLUINTEGER 변수를 가리키도록 SQL_ATTR_PARAMS_PROCESSED_PTR 특성을 설정합니다.
SQL_ATTR_PARAMS_STATUS_PTR을 매개 변수 상태 표시를 보유하는 SQLUSSMALLINT 변수의 배열[S]을 가리키도록 설정합니다.
SQLPrepare를 호출하여 문을 준비합니다.
필요에 따라 SQLNumParams를 호출하여 준비된 문의 매개 변수 수를 확인합니다.
필요에 따라 준비된 문의 각 매개 변수에 대해 SQLDescribeParam을 호출하여 매개 변수 정보를 가져옵니다.
각 매개 변수 표식에 대해 다음 작업을 수행합니다.
S 매개 변수 버퍼 배열을 할당하여 데이터 값을 저장합니다.
데이터 길이를 저장할 S개의 매개 변수 버퍼 배열을 할당합니다.
SQLBindParameter 를 호출하여 매개 변수 데이터 값과 데이터 길이 배열을 문 매개 변수에 바인딩합니다.
매개 변수가 실행 시 데이터 텍스트 또는 이미지 매개 변수인 경우 설정합니다.
실행 시 데이터 매개 변수를 사용하는 경우 설정합니다.
준비된 문의 각 실행에 대해 다음을 수행합니다.
S 데이터 값 및 S 데이터 길이를 바인딩된 매개 변수 배열에 넣습니다.
SQLExecute를 호출하여 준비된 문을 실행합니다.
실행 시 데이터 입력 매개 변수를 사용하는 경우 SQLExecute는 SQL_NEED_DATA 반환합니다. SQLParamData 및 SQLPutData를 사용하여 청크로 데이터를 보냅니다.
행 단위 바인딩 매개 변수를 사용하여 문을 준비하려면
구조의 배열[S]을 할당합니다. 여기서 S는 매개 변수 집합의 수입니다. 구조에는 각 매개 변수에 대해 요소가 하나씩 포함되고 각 요소에는 두 부분이 포함됩니다.
첫 번째 부분은 매개 변수의 데이터를 보유하는 적절한 데이터 형식의 변수입니다.
두 번째 부분은 상태 표시를 보유하는 SQLINTEGER 변수입니다.
SQLSetStmtAttr을 호출하여 다음 특성을 설정합니다.
SQL_ATTR_PARAMSET_SIZE를 매개 변수 집합 수(S)로 설정합니다.
SQL_ATTR_PARAM_BIND_TYPE 1단계에서 할당된 구조체의 크기로 설정합니다.
처리된 매개 변수 수를 보유하도록 SQLUINTEGER 변수를 가리키도록 SQL_ATTR_PARAMS_PROCESSED_PTR 특성을 설정합니다.
SQL_ATTR_PARAMS_STATUS_PTR을 매개 변수 상태 표시를 보유하는 SQLUSSMALLINT 변수의 배열[S]을 가리키도록 설정합니다.
SQLPrepare를 호출하여 문을 준비합니다.
각 매개 변수 표식에 대해 SQLBindParameter를 호출하여 1단계에서 할당된 구조 배열의 첫 번째 요소에서 매개 변수 데이터 값 및 데이터 길이 포인터를 해당 변수를 가리킵니다. 매개 변수가 실행 시 데이터 매개 변수인 경우 설정합니다.
준비된 문의 각 실행에 대해 다음을 수행합니다.
바인딩된 매개 변수 버퍼 배열을 데이터 값으로 채웁니다.
SQLExecute를 호출하여 준비된 문을 실행합니다. 드라이버는 각 매개 변수 집합에 대해 한 번씩 SQL 문 S 시간을 효율적으로 실행합니다.
실행 시 데이터 입력 매개 변수를 사용하는 경우 SQLExecute는 SQL_NEED_DATA 반환합니다. SQLParamData 및 SQLPutData를 사용하여 청크로 데이터를 보냅니다.