Php ms sql connect
Подключение MS SQL к PHP 5.3 и выше
Недавно передо мной встала задача: работать с MS SQL из PHP. Поиск в Google по ключевым словам «php mssql» и подобным дал уйму ссылок с примерно одинаковой инструкцией:
— раскомментировать в php.ini строчку extension=php_mssql.dll;
— перезапустить Апач/Денвер;
— наслаждаться.
Однако выяснилось, что начиная с версии 5.3 в состав дистрибутива PHP это расширение не входит и, более того, не поддерживается. Для работы с MS SQL рекомендуется драйвер SqlSrv от Microsoft. Пошаговой инструкции по работе с ним найти не смог, поэтому после ряда проб и ошибок написал свою, которую и предлагаю вашему вниманию.
Первое, с чем придётся столкнуться — это соответствие версий PHP, MS SQL, SqlSrv и Windows.
SqlSrv доступен двух версий: 2.0 и 3.0. Версия 2.0 работает только c MS SQL 2008, при этом поддерживает PHP версий 5.2 и 5.3; версия 3.0 работает только с MS SQL 2012, а PHP поддерживает версий 5.3 и 5.4. При этом необходимо помнить, что MS SQL 2012 работает только под Windows Vista и выше.
На моей машине стоит Windows XP, поэтому были взяты: MS SQL 2008, PHP 5.3.5 и SqlSrv 2.0.
Сначала нужно установить сам сервер MS SQL; неожиданностей в установке нет, обо всех проблемах установщик сообщает вовремя и даёт возможность исправить. Желательно также установить MS SQL Server Management Studio: средство управления базами данных. Установка похожа на установку сервера.
Установка связки Apache+PHP описывалась много и подробно, так что здесь не будем её касаться.
Теперь нужно подключить SqlSrv к PHP. Скачанный с сайта Microsoft дистрибутив — это самораспаковывающийся архив с несколькими библиотеками .dll, для разных версий PHP. Так, я использовал php_sqlsrv_53_ts_vc6.dll. Здесь 53 − ветка PHP (5.3.x), ts − Thread Safe дистрибутив, vc6 − использованный компилятор. Если нужно, то эти сведения можно найти в первом же блоке phpinfo(). Подходящую библиотеку нужно скопировать в каталог ext, а также добавить в php.ini строчку
Если PHP только что установлен, нужно также не забыть раскомментировать строчку
PHP готов к работе. Осталось подготовить MS SQL; дело в том, что после установки у него отключены все клиентские протоколы, кроме «Общая память». Нужно их включить; делается это в приложении SQL Server Configuration Manager, идущая в комплекте с сервером.
Теперь все компоненты настроены, и можно проверять работу всей системы. Для этого подойдёт такой скрипт:
function FormatErrors( $errors )
<
echo «Error information:
«;
foreach ( $errors as $error )
<
echo «SQLSTATE: «.$error[‘SQLSTATE’].»
«;
echo «Code: «.$error[‘code’].»
«;
echo «Message: «.$error[‘message’].»
«;
>
>
$serverName = «Имя сервера»; // Имя сервера задавалось при установке; его также можно увидеть при запуске Management Studio
$conn = sqlsrv_connect( $serverName);
if( $conn === false )
Если всё правильно, то на экране будет строчка
И последнее: для работы с базой данных из PHP нужно использовать функции семейства sqlsrv_, а не mssql_.
Данная статья не подлежит комментированию, поскольку её автор ещё не является полноправным участником сообщества. Вы сможете связаться с автором только после того, как он получит приглашение от кого-либо из участников сообщества. До этого момента его username будет скрыт псевдонимом.
mssql_connect
(PHP 4, PHP 5, PECL odbtp >= 1.1.1)
mssql_connect — Открывает соединение с MS SQL server
Эта функция УДАЛЕНА в PHP 7.0.0.
Есть следующие альтернативы:
Описание
mssql_connect() устанавливает соединение с MS SQL server.
Подключение к серверу будет закрыто как только будет завершено выполнение скрипта, если его не закрыть раньше с помощью функции mssql_close() .
Список параметров
Сервер MS SQL. Может также включать номер порта, например hostname:port (Linux), или hostname,port (Windows).
Если mssql_connect() будет вызвана повторно с теми же аргументами, то нового соединения создано не будет, а ,вместо этого, будет возвращен уже существующий идентификатор подключения. Этот параметр изменяет такое поведение, и заставляет mssql_connect() всегда создавать новое соединение, даже если mssql_connect() была вызвана ранее с такими же параметрами.
Возвращаемые значения
Возвращает идентификатор соединения с MS SQL в случае успеха, или FALSE при ошибке.
Список изменений
Версия | Описание |
---|---|
5.1.0 | Добавлен параметр new_link |
Примеры
Пример #1 Пример использования mssql_connect()
при использовании нестандартного порта
$server = ‘KALLESPCSQLEXPRESS’ ;
// Подключение к MSSQL
$link = mssql_connect ( $server , ‘sa’ , ‘phpfi’ );
if (! $link ) <
die( ‘Something went wrong while connecting to MSSQL’ );
>
?>
Смотрите также
- mssql_close() — Закрывает соединение с MS SQL Server
- mssql_pconnect() — Открывает постоянное соединение с MS SQL
User Contributed Notes 40 notes
If someone encounters the interesting problem in which PHP can connect to a MSSQL server from the command line but not when running as an Apache module: SELinux prevents Apache (and therefore all Apache modules) from making remote connections by default.
This solved the problem in CentOS:
# setsebool -P httpd_can_network_connect=1
If you use PHP on Windows with Apache as a web server, you may get problems with authentication to MS SQL Server even when you supply all valid credentials.
Check your php.ini file:
; Use NT authentication when connecting to the server
mssql.secure_connection = On
If you have secure_connection = On, make sure that you provide valid credentials in the properties for Apache service in the System Services box. Then you should not send DB username and password from your script to MSSQL Server.
If you want to use specific credentials from a PHP script, then set mssql.secure_connection = Off in your php.ini
Cent OS — Remote SQL server connection
$link = mssql_connect(72.xx.xxx.xxx, username, password);
If you are not getting success, please check
There is certainly a php-mssql package available in the extras repository so just a `yum install php-mssql` should sort that out — it pulls in freetds as a dependency too. If you already have those installed but it doesn’t seem to be connecting, the one possibility is that you are being blocked by SELinux. To check that run
# getsebool -a | grep httpd_can_network_connect
httpd_can_network_connect —> on
httpd_can_network_connect_db —> on
and to enable them if they are not on, do
setsebool -P httpd_can_network_connect 1
setsebool -P httpd_can_network_connect_db 1
The following method: serverinstance
does’nt work on unix systems.
An instance is nothing more than specific port address different than 1433. so just discover the port on mssql server and then try to connect using:
In unix the port is specified by : not by ,
For anyone who have to connect to crappy SQL SERVER with \computer_nameinstance_name and failed to connect. There are couple of thing you need do.
1). There’s no needs to install SQL client software in your app server. This would keep your server clean.
2). run cliconfg.exe setup alias in case you needed
3). last and most important, do NOT use ntwdblib.dll came with PHP 4.4.x. It’s not most current. The version I’m using is: 8.00.194 with 274,489 Bytes. And make sure you put this file in your system32 folder.
For those trying to connect PHP 5.2 to a 2005 Microsoft SQL Server Analysis Services (SSAS) cube and execute MDX queries, you have to establish a link via a trusted connection from the Database Service to SSAS using a stored procedure, then execute the stored procedure via PHP.
Here is an example stored procedure that retrieves records from the Adventure Works sample cube that ships with SSAS.
From SQL Server Query Analyzer, you could test it as:
From PHP, you would execute something like the following:
$resultset = mssql_query(«exec testMDX»,$res_id);
then loop thorugh the result set.
— STORED PROCEDURE BEGIN
set ANSI_NULLS ON — Must be enabled at time Stored Proc is created
set QUOTED_IDENTIFIER ON — Must be enabled at time Stored Proc is created
GO
Create Procedure [dbo].[testMDX]
as
BEGIN
SET ANSI_WARNINGS ON: — Must be enabled
SET ANSI_NULLS ON; — Must be enabled
Declare
@SQL varchar(1200), — Variable to hold SQL query
@MDX varchar (1000), — Variable to hold MDX query
;
— Establish a link to Analysis Server
exec sp_addlinkedserver
@server=’linked_olap’, — Alias used to reference the link
@srvproduct=», — Not used
@prov , — OLAP driver
@datasrc=’servername’, — Database server name
@catalog=’Adventure Works DW Standard Edition’ — Database name
;
— Analysis Server requires a TRUSTED connection
exec sp_addlinkedsrvlogin
@rmtsrvname = ‘linked_olap’, — Alias used to reference the link
@useself = ‘false’, — Use own credentials
@locallogin = NULL, — Apply to all local logins
@rmtuser = ‘domainusername’, — Remote user name
@rmtpassword = ‘xyz123’ — Remote user password
;
— Create a temporary table that will be used to hold the MDX output
create table #temp_table (column1 text null, column2 text null);
— Setup a string to hold the MDX so that the precompiler does not try to validate the syntax
SET @MDX = ‘SELECT [Product].[Category].members ON ROWS,
FROM [Adventure Works] ‘ ;
— Setup a string to insert the MDX results into the temporary table
SET @SQL = ‘Insert into #temp_table SELECT * FROM OpenQuery(linked_olap,»’+@MDX+»’)’;
— Execute the SQL and remote MDX query
EXEC (@SQL) ;
— Select the results from the temporary table to return to the calling program
Select column1, column2 from #temp_table ;
— Drop the temporary table
drop table #temp_table;
— Release the TRUSTED connection
exec sp_droplinkedsrvlogin ‘linked_olap’, NULL ;
— Release the link to the Analysis Server
exec sp_dropserver ‘linked_olap’ ;
Как подключиться к Microsoft SQL Server через PHP
В этой статье мы расскажем о всех тонкостях подключения к MS SQL серверу, для работы с ним через PHP .
Мы будем рассматривать SQL Server 2014 . На ранних версиях этот процесс может немного отличаться.
Давайте определим, что мы уже имеет установленный пакет SQL Server на каком то VPS или сервере с ОС Windows (Например, заказанного у ihc.ru), либо установленный на вашем локальном компьютере для тестов.
Так же соответственно на сервере стоит PHP версии 5.2+ или у вас установлен локальный сервер, вроде OpenServer .
Теперь нужно скачать и установить PHP driver для SQL Server — вот ссылка на официальный сайт.
На данный момент там есть четыре версии драйвера 2.0, 3.0, 3.1, 3.2. Далее приведена таблица с совместимостью с PHP :
Microsoft Drivers for PHP for SQL Server Version | Supported PHP Versions |
---|---|
Microsoft Drivers for PHP for SQL Server Version | Supported Windows Server |
---|---|