Дмитрий Верещака, http://dmitry.rsl.ru
Если Вы планируете создавать свой динамический сайт на платформе Windows, то у Вас скорее всего возникнет задача выбора СУБД для хранения информации (с языком, на котором Вы будете его программировать, судя по всему, вопросов не возникает). Одним из вариантов её решения, может оказаться использование MS Access в качестве SQL-сервера. Далее будет описано, как в скрипте, написанном на PHP, обратиться к базе данных MS Access.
К сожалению, в PHP нет встроенных средств для работы с этой СУБД, что, однако не исключает совместной их работы - для подключения к базе мы будем использовать ODBC.
Первым делом мы должны создать так называемый DSN Source.
Для этого (рассматривается вариант, когда у пользователя установлена ОС
Windows 2000 Rus) в панели управления мы должны выбрать пункт
Администрирование, а затем Источники данных (ODBC).
Далее, в появившемся окне (рис.1)
Теперь, когда у нас есть источник данных ODBC, мы можем воспользоваться
функцией odbc_connect для подключения к нашей базе:
Чтобы передать запрос в СУБД, мы можем воспользоваться функцией
odbc_exec:
<?
$x=odbc_connect("test","test","test");
?>
Если после выполнения этого примера открыть базу test в MS Access,
то мы обнаружим, что там появилась новая таблица test с полями f1 и f2
целочисленного и строкового типов соответственно; в таблице будут
две записи с данными, которые были указаны в запросе.
<?
$res=odbc_exec($x,"create table test (f1 integer, f2 varchar(10))");
$res=odbc_exec($x,"insert into test (f1,f2) values(1,'qwerty')");
$res=odbc_exec($x,"insert into test (f1,f2) values(2,'asdfgh')");
?>
К сожалению, не все функции для работы с ODBC корректно работают с MS Access,
например, это функции odbc_num_rows и odbc_fetch_array. Так, в той версии PHP, что установлена на моём компьютере, PHP вообще выдаёт
сообщение, что функция odbc_fetch_array ему не известна. Но эти проблемы решаются, если описать две следующие функции и использовать их
вместо ранее упоминавшихся:
Результат выполнения этого примера приведён ниже:
<?
function xodbc_num_rows($sql_id, $CurrRow = 0)
{
$NumRecords = 0;
odbc_fetch_row($sql_id, 0);
while (odbc_fetch_row($sql_id))
{
$NumRecords++;
}
odbc_fetch_row($sql_id, $CurrRow);
return $NumRecords;
}
function xodbc_fetch_array($result, $rownumber=-1) {
if ($rownumber < 0) {
odbc_fetch_into($result, &$rs);
} else {
odbc_fetch_into($result, &$rs, $rownumber);
}
foreach ($rs as $key => $value) {
$rs_assoc[odbc_field_name($result, $key+1)] = $value;
}
return $rs_assoc;
}
$res=odbc_exec($x,"select * from test");
$cnt=xodbc_num_rows($res);
?>
<table border=1 cellspacing=0 cellpadding=4>
<tr><td>f1</td><td>f2</td></tr>
<?
for ($i=0;$i<$cnt;$i++) {
$row=xodbc_fetch_array($res,$i+1);
echo '<tr><td>'.$row['f1'].'</td><td>'.$row['f2'].'</td></tr>';
}
?>
</table>
f1 | f2 |
1 | qwerty |
2 | asdfgh |
Таким образом, теперь, если у Вас возникнет задача подключения к базе MS Access из PHP, Вы смело сможете её решить в кратчайшие сроки.