Исключение нулевого указателя - это индикатор того, что вы используете объект, не инициализируя его.
Например, ниже - класс ученика, который будет использовать его в нашем коде.
public class Student {
private int id;
public int getId() {
return this.id;
}
public setId(int newId) {
this.id = newId;
}
}
Приведенный ниже код дает вам исключение с нулевым указателем.
public class School {
Student obj_Student;
public School() {
try {
obj_Student.getId();
}
catch(Exception e) {
System.out.println("Null Pointer ");
}
}
}
Поскольку вы используете Obj_Student
, но вы забыли инициализировать его, как в правильном коде, показанном ниже:
public class School {
Student obj_Student;
public School() {
try {
obj_Student = new Student();
obj_Student.setId(12);
obj_Student.getId();
}
catch(Exception e) {
System.out.println("Null Pointer ");
}
}
}
Это очень сложная проблема. Вот подробные сведения о совместимости, поэтому кто-то другой может потратить меньше времени на поиск и попытку.
sqlsrv существует в двух (+ неофициальных) версиях, они совместимы только с 32-битным PHP. В настоящее время нет версии для 64-битного PHP.
Другой способ доступа к SQL Server 2000 с PHP 5.4 - через расширение odbc. Можно подключиться с помощью трех драйверов ODBC для SQL Server 2000:
Код для подключения для каждого из этих драйверов ODBC:
$connection_string = 'DRIVER={SQL Server};SERVER=mbsql;DATABASE=vg1';
$connection_string = 'DRIVER={SQL Native Client};SERVER=mbsql;DATABASE=vg1';
$connection_string = 'DRIVER={SQL Server Native Client 10.0};SERVER=mbsql;DATABASE=vg1';
$connection = odbc_connect( $connection_string, $user, $pass );
Эти соединения работают с PHP 32-битным и 64-битным. Я еще не тестировал, какой из них лучший.