Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Объектно-ориентированное программирование на PHP. Авторы: Кузнецов М.В., Симдянов И.В. Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. PHP. Практика создания Web-сайтов (второе издание). Авторы: Кузнецов М.В., Симдянов И.В. PHP на примерах (2 издание). Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум MySQL

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: PHP + MS SQL
 
 автор: Киналь   (23.04.2012 в 18:03)   письмо автору
 
 

Мне нужно из PHP работать с базой MS SQL, всё работает на одной машине под Windows. Можно поставить отдельно PHP, MS SQL и Apache, но, каюсь, никогда подобным не занимался, ограничиваясь Денвером. Посему вопрос: нет ли в природе готовой сборки, наподобие того же Денвера, но с MS SQL?

  Ответить  
 
 автор: confirm   (23.04.2012 в 18:30)   письмо автору
 
   для: Киналь   (23.04.2012 в 18:03)
 

Так в Денвере есть библиотека работы с MS SQL - php_mssql.dll, надо раскомментировать в настройках и пробовать.

  Ответить  
 
 автор: Киналь   (23.04.2012 в 18:33)   письмо автору
 
   для: confirm   (23.04.2012 в 18:30)
 

Библиотека есть, сервера нет) Надо ещё его ставить. Можно, конечно, но Денвер избаловал своим «распаковал и работай»)

  Ответить  
 
 автор: confirm   (23.04.2012 в 19:01)   письмо автору
 
   для: Киналь   (23.04.2012 в 18:33)
 

А скачать и добавить, это мало будет для утешения, и обязательно надо новый сервер, так чтобы от души наковыряться? )

  Ответить  
 
 автор: Киналь   (23.04.2012 в 21:18)   письмо автору
 
   для: confirm   (23.04.2012 в 19:01)
 

Ну-у... Хочется же верить в «волшебную таблетку»=)

  Ответить  
 
 автор: cheops   (23.04.2012 в 19:51)   письмо автору
 
   для: Киналь   (23.04.2012 в 18:33)
 

Да там тоже все не сложно, качайте Express-версию - она бесплатная, ставьте и пользуйтесь. В состав входит довольно приличный менеджер запросов, т.е. работать будет удобнее, чем с MySQL, аналог phpMyAdmin вам не потребуется.

  Ответить  
 
 автор: Киналь   (23.04.2012 в 21:18)   письмо автору
 
   для: cheops   (23.04.2012 в 19:51)
 

Ну, стало быть, так и попробую. Спасибо!

  Ответить  
 
 автор: Киналь   (24.04.2012 в 12:33)   письмо автору
 
   для: Киналь   (23.04.2012 в 18:03)
 

Хм, появилась всё же проблема... В том PHP, что в составе Денвера, в phpinfo() среди Configure Command оказалось вот что: «"--without-mssql" "--without-pdo-mssql"». Соответственно, MS SQL не работает, несмотря на подключённое расширение. Как же быть?

  Ответить  
 
 автор: cheops   (24.04.2012 в 13:16)   письмо автору
 
   для: Киналь   (24.04.2012 в 12:33)
 

Поставьте полноценную связку, если что-то не заладится, поможем.

  Ответить  
 
 автор: Киналь   (24.04.2012 в 14:07)   письмо автору
 
   для: cheops   (24.04.2012 в 13:16)
 

Ох-хо... Придётся всё-таки перебороть лень)
А что тут помогут — не сомневаюсь, спасибо!

  Ответить  
 
 автор: Киналь   (28.04.2012 в 23:45)   письмо автору
 
   для: Киналь   (23.04.2012 в 18:03)
 

Наконец-то собрался и поставил связку Apache+PHP; но опять та же проблема — у дистрибутива, который взял по ссылке отсюда, поддержка MS SQL тоже выключена. Где же взять дистрибутив с её поддержкой?

UPD Последний стабильный релиз (5.4.1), скачанный с php.net, даёт ту же информацию. Мне теперь чего, ещё и PHP перекомпилировать, что ли?=)

  Ответить  
 
 автор: cheops   (29.04.2012 в 08:30)   письмо автору
 
   для: Киналь   (28.04.2012 в 23:45)
 

Погодите, в дистрибутиве поддержка отключена на уровне ядра, а расширения php_mssql.dll, php_pdo_mssql.dll вполне себе имеют место быть - нужно только подключить нужное через php.ini и все должно заработать.

  Ответить  
 
 автор: Киналь   (29.04.2012 в 12:03)   письмо автору
 
   для: cheops   (29.04.2012 в 08:30)
 

Так что ж оно тогда на Денвер не ставилось?.. Нда. Сейчас попробую на связку поставить, конечно.

UPD Ни в php.ini нет упоминаний о php_mssql.dll, ни самого файла в дистрибутиве (ни в вашем, ни в свежем). Всё интереснее и интереснее=) Ищу дальше.

  Ответить  
 
 автор: cheops   (29.04.2012 в 12:29)   письмо автору
 
   для: Киналь   (29.04.2012 в 12:03)
 

Папка ext есть? Если есть, что в ней?

  Ответить  
 
 автор: Киналь   (29.04.2012 в 12:48)   письмо автору
 
   для: cheops   (29.04.2012 в 12:29)
 

Всё оказалось проще. Как сказано на сайте PHP, поддержка этого расширения прекращена, начиная с версии 5.3. Ему на смену пришёл драйвер от Microsoft, с которым сейчас и пытаюсь разобраться, будь он неладен.

  Ответить  
 
 автор: Киналь   (30.04.2012 в 19:06)   письмо автору
 
   для: Киналь   (29.04.2012 в 12:48)
 

Вроде разобрался. Впечатлений хватило на небольшую статью) Писал для habrahabr.ru, но её уже сграбили сюда.

  Ответить  
 
 автор: AnatolIv   (20.10.2013 в 15:14)   письмо автору
 
   для: Киналь   (30.04.2012 в 19:06)
 

Здравствуйте,

установил библиотеки от Microsoft, использовал для проверки Ваш код, приведенный в статье на Хабре - подключение к серверу MSSQL проходит успешно, однако при попытке выполнить запрос SeLECT выдается пустой результат. При выполнении того же запроса средствами MS SQL Management Studio результат успешный. В чем может быть причина?

Код PHP:

$sql = "SELECT [sensor1] FROM [zigbee].[dbo].[Sensors]";
$result=sqlsrv_query($conn,$sql) or die("Can't query \"$sql\"\n");
$row_count = sqlsrv_num_rows( $result );
$p=sqlsrv_fetch_array($result);
$number =sqlsrv_num_rows($result);

if ($row_count === false)
echo "Error in retrieveing row count.";
else
echo $row_count;
if ($p === false)
echo "Error in retrieveing p.";
else
echo $p;
if ($number === false)
echo "Error in retrieveing number.";
else
echo $number;

  Ответить  
 
 автор: Леха   (17.11.2012 в 14:19)
 
   для: Киналь   (29.04.2012 в 12:48)
 

Всем привет!

  Ответить  
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования