
SQLSRV_prepare 함수를 사용할 때 오류가 발생하는 이유는 SQLSRV_prepare 함수가 SQLSRV_connect 함수로 연결된 서버에만 사용할 수 있기 때문입니다.
이러한 오류를 해결하기 위해 SQLSRV_prepare 함수를 사용하는 방법은 SQLSRV_connect 함수를 사용하여 서버에 연결한 후 SQLSRV_prepare 함수를 사용하는 것입니다.
예를 들어, 다음과 같이 사용할 수 있습니다.
#hostingforum.kr
php
$serverName = "192.168.1.100";
$dBName = "testdb";
$uid = "testuser";
$pwd = "testpassword";
$connectionInfo = array( "Database"=>$dBName, "UID"=>$uid, "PWD"=>$pwd);
$conn = sqlsrv_connect($serverName, $connectionInfo);
if( $conn === false ) {
echo "Connection could not be established.n";
exit;
}
$stmt = sqlsrv_prepare($conn, "SELECT * FROM 테이블명");
if( !$stmt ) {
echo "Error in preparing statement.n";
exit;
}
SQLSRV_prepare 함수를 사용하는 경우 SQLSRV_query 함수를 사용하는 것과 차이점은 SQLSRV_prepare 함수는 SQL문장을 미리 준비하여 SQLSRV_execute 함수를 사용하여 실행할 수 있습니다. 반면, SQLSRV_query 함수는 SQL문장을 직접 실행하여 결과를 얻을 수 있습니다.
예를 들어, 다음과 같이 사용할 수 있습니다.
#hostingforum.kr
php
$stmt = sqlsrv_prepare($conn, "SELECT * FROM 테이블명");
sqlsrv_execute($stmt);
while($row = sqlsrv_fetch_array($stmt, SQLSRV_FETCH_ASSOC)) {
echo $row['컬럼명'] . "n";
}
또한, SQLSRV_prepare 함수를 사용하는 경우 SQLSRV_query 함수를 사용하는 것보다 성능이 향상될 수 있습니다. 왜냐하면 SQLSRV_prepare 함수는 SQL문장을 미리 준비하여 SQLSRV_execute 함수를 사용하여 실행할 수 있기 때문입니다.
반면, SQLSRV_query 함수는 SQL문장을 직접 실행하여 결과를 얻을 수 있기 때문에 성능이 떨어질 수 있습니다.
따라서, SQLSRV_prepare 함수를 사용하는 것이 좋습니다.
2025-06-04 12:27