Есть вопрос?
Зайди на форум

Поиск на сайте: Advanced

Denix - новый дистрибутив Linux. Русификация Ubuntu и установка кодеков

dkws.org.ua
Форум сайта dkws.org.ua
 
Главная    ТемыТемы    АльбомАльбом    РегистрацияРегистрация 
 ПрофильПрофиль   Войти и проверить личные сообщенияВойти и проверить личные сообщения   ВходВход 

Работа с MS Access в PHP

 
Начать новую тему Ответить на тему    Список форумов dkws.org.ua -> PHP
 
Автор Сообщение
den

Старожил


Зарегистрирован: 31.01.2006
Сообщения: 13870
Откуда: Кировоград, Украина

СообщениеДобавлено: Пн Фев 12, 2007 2:34 pm    Заголовок сообщения: Работа с MS Access в PHP
Ответить с цитатой

Работа с MS Access в PHP

Дмитрий Верещака, http://dmitry.rsl.ru

Если Вы планируете создавать свой динамический сайт на платформе Windows, то у Вас скорее всего возникнет задача выбора СУБД для хранения информации (с языком, на котором Вы будете его программировать, судя по всему, вопросов не возникает). Одним из вариантов её решения, может оказаться использование MS Access в качестве SQL-сервера. Далее будет описано, как в скрипте, написанном на PHP, обратиться к базе данных MS Access.

К сожалению, в PHP нет встроенных средств для работы с этой СУБД, что, однако не исключает совместной их работы - для подключения к базе мы будем использовать ODBC.

Первым делом мы должны создать так называемый DSN Source. Для этого (рассматривается вариант, когда у пользователя установлена ОС Windows 2000 Rus) в панели управления мы должны выбрать пункт Администрирование, а затем Источники данных (ODBC). Далее, в появившемся окне (рис.1)



выбираем вкладку системный DSN, нажимаем кнопку добавить, выбираем драйвер MS Access (рис.2)



и нажимаем кнопку готово. В поле ввода имя источника данных пишем имя, по которому впоследствии мы сможем обратиться к нашей базе данных, например, test, затем нажимаем кнопку выбрать и указываем, где у нас на диске находится наш файл с БД (рис. 3)



Затем, если в этом есть необходимость, можем задать имя пользователя и пароль для доступа к БД через ODBC, нажав на кнопку дополнительно (рис. 4)



Теперь, когда у нас есть источник данных ODBC, мы можем воспользоваться функцией odbc_connect для подключения к нашей базе:

<?
$x=odbc_connect("test","test","test");
?>

Чтобы передать запрос в СУБД, мы можем воспользоваться функцией odbc_exec:
<?
$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')");
?>

Если после выполнения этого примера открыть базу test в MS Access, то мы обнаружим, что там появилась новая таблица test с полями f1 и f2 целочисленного и строкового типов соответственно; в таблице будут две записи с данными, которые были указаны в запросе.

К сожалению, не все функции для работы с 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, Вы смело сможете её решить в кратчайшие сроки
Вернуться к началу
Посмотреть профиль Отправить личное сообщение dhsilabs@jabber.ru
Артур

Новенький


Зарегистрирован: 14.10.2007
Сообщения: 14

СообщениеДобавлено: Пт Dec 07, 2007 6:30 pm    Заголовок сообщения:
Ответить с цитатой

Warning: odbc_connect() [function.odbc-connect]: SQL error: [Microsoft][Драйвер ODBC Microsoft Access]Общий сбой Недостаточно сведений для подключения к DSN с помощью SQLConnect. Воспользуйтесь SQLDriverConnect., SQL state Попробовал но почему то не получилось

Настроил DSN как на картинках,затем копирнул в в файл сценария

<?
$x=odbc_connect("test","test","test");
?>

<?
$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')");
?>

И мне выдало:
S1000 in SQLConnect in c:\program files\apache group\Apache\htdocs\1.php on line 6

Warning: odbc_exec(): supplied argument is not a valid ODBC-Link resource in c:\program files\apache group\Apache\htdocs\1.php on line 8

Warning: odbc_exec(): supplied argument is not a valid ODBC-Link resource in c:\program files\apache group\Apache\htdocs\1.php on line 9

Warning: odbc_exec(): supplied argument is not a valid ODBC-Link resource in c:\program files\apache group\Apache\htdocs\1.php on line 10
Что я не пиравильно сделал?
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Артур

Новенький


Зарегистрирован: 14.10.2007
Сообщения: 14

СообщениеДобавлено: Пт Dec 07, 2007 6:44 pm    Заголовок сообщения:
Ответить с цитатой

Извиняюсь за глупый вопрос.Все нормально работает.Оказывается я DSN не правильно настроил.
Вернуться к началу
Посмотреть профиль Отправить личное сообщение
Показать сообщения:   
Начать новую тему Ответить на тему    Список форумов dkws.org.ua -> PHP Часовой пояс: GMT
Страница 1 из 1
 Главная страница сайта
 
Перейти:  
Вы не можете начинать темы
Вы не можете отвечать на сообщения
Вы не можете редактировать свои сообщения
Вы не можете удалять свои сообщения
Вы не можете голосовать в опросах
© Колисниченко Денис