백엔드 개발 PHP 튜토리얼 Linux에서 sqlSrv를 사용하여 PHP를 Microsoft 데이터베이스에 연결하는 방법

Linux에서 sqlSrv를 사용하여 PHP를 Microsoft 데이터베이스에 연결하는 방법

Mar 03, 2018 pm 01:53 PM
linux php

PHP는 sqlSrv를 사용하여 Microsoft의 SQLSERVER 데이터베이스에 연결할 때 pdo_srv 확장자를 사용해야 합니다.
pdo_srv 확장 설치는 pecl을 이용해 직접 설치 가능합니다

본 글을 작성하는 환경은
ubuntu 16.04 LTS
php 7.0.27
unixODBC 2.3.5
FreeTDS 1.00.82
2018-03-02

페클
프로그램은 PHP 설치 디렉터리 아래의 bin 디렉터리에 있습니다. PHP 디렉터리가 Linux 환경 변수에 없는 경우입니다. 또는 pecl 프로그램이 시스템 bin 경로에 연결되어 있지 않아 pecl 프로그램이 설치되지 않았다는 메시지가 표시됩니다.

sqlsrv를 설치하려면 unixODBC 지원이 필요하므로 설치 전에 unixODBC를 설치하지 않은 경우 unixODBC를 먼저 설치해야 하며 unixODBC는 SQLSERVER에 연결하기 위해 FreeTDS가 필요합니다. unixODBC는 일반 인터페이스 집합만 정의하고 특정 인터페이스가 없기 때문입니다. 구현 방법.

1. FreeTDS 설치
a), 다운로드

http://www.freetds.org/

b), 컴파일 및 설치

./configure --with-tdsver=auto --prefix=/usr/local/freetds --enable-msdblib --with-gnu-ld --enable-shared --enable-static --with-unixodbc=/usr/localmake
make install
로그인 후 복사
로그인 후 복사

일부 온라인 튜토리얼에서는 –with-tdsver= 8.0, 컴파일 시 오류가 발생했다고 보고했습니다. 구체적인 지원 값은 ./configure –help

에서 with-tdsver 설명을 확인하실 수 있습니다. 설치가 완료되면 /usr/local/에 etc 디렉터리가 생성됩니다. freetds.conf 파일을 사용해야 합니다.
c), 구성
freetds.conf 파일을 구성합니다.

구성할 필요가 없습니다. freetds.conf를 구성하지 않는 방법은 unixODBC

[global]#全局配置tds version = auto#更多的配置可以参考freetds官方文档,我这里这样配置已经够用了[servertag]#定义一个叫 servertag 的节点,这个节点的名称可以自定义的,不是固定#所有 # 符号的内容都可以不写在配置文件中,这里只是注释解释用#更多的细节配置看官方描述#数据库的连接IP地址host = 192.168.9.12 #数据库的端口port = 1433 #连接时默认打开的库名,【可以不配置此项】database = master 
#tds version 有全局配置,这里也可以不写tds version = auto
로그인 후 복사
로그인 후 복사

구성 링크에서 찾을 수 있습니다. 2. unixODBC 설치

a), 다운로드

  https://sourceforge.net/projects/unixodbc/files/unixODBC/
  http://www.unixodbc.org/
  以上两个网站都可以下载到,建议到第二个官网下载吧。
로그인 후 복사
로그인 후 복사

b), 컴파일 및 설치

./configure --prefix=/usr/local/unixODBC --includedir=/usr/include  --libdir=/usr/lib -bindir=/usr/bin --sysconfdir=/etcmake 
make install
로그인 후 복사
로그인 후 복사

c), 구성
/etc/odbc.ini에 구성 추가

인터넷에는 컴파일 및 설치가 /usr/local/etc/odbc.ini에 있다는 튜토리얼이 있습니다
, 이 파일은 컴파일 후에 생성되지만 이 파일의 구성은 적용되지 않습니다. /etc/odbc.ini

[ODBC Data Sources]#描述而已,没有测过不写行不行,理论上可行SQLSERVER2018912 = 9.12 DB

[SQLSERVER2018912]#Driver 指向的目录是FreeTDS编译生成的文件,类似一个驱动文件,稍后讲解安装方法Driver = /usr/local/freetds/lib/libtdsodbc.so
Description  = 9.12 DB,文字描述
Trace = No#Server 可以直接写 FreeTDS的freetds.conf 中配置的servertag节点名#使用freetds.conf配置时,port 也不用配置了。#因为在此直接写server IP时能配置的选项很少,而freetds.conf可以配置的细节更多#此处我已经配置了IP,freetds.conf中其实就可以不用配置。只要安装好freetds即可Server = 192.168.9.12Port = 1433#7.4或auto应该都可以。没有详细研究过TDS_Version = 7.4[Default]#全局默认配置。理论上可以不写#同上,默认使用Driver = /usr/local/freetds/lib/libtdsodbc.so
로그인 후 복사
로그인 후 복사

에서 구성해야 합니다. 위 구성이 완료된 후 테스트할 수 있습니다.
unixODBC 컴파일 시 생성된 isql 프로그램을 이용하여 테스트해 보세요. /usr/bin/isql

/usr/bin/isql SQLSERVER2018912 数据库账号 密码
로그인 후 복사
로그인 후 복사

isql 경로는 isql –help
를 통해 확인할 수 있다. 설정에 오류가 없다면 데이터베이스로 연결되어 있는 것을 확인할 수 있다. SQL문을 사용하여 쿼리할 수 있습니다.
unixODBC 구성이 완료되면 PHP 확장을 설치할 수 있습니다

3. PHP sqlsrv 확장 설치

pecl install sqlsrv
로그인 후 복사
로그인 후 복사

설치 후 php.ini에서 확장을 로드한 다음 아파치를 다시 시작해야 적용됩니다.
편집 후 화면에 출력되는 내용을 주목해주세요

이 글을 작성하는 환경은
우분투 16.04 LTS
PHP 7.0.27
유닉스ODBC 2.3.5
무료TDS 1.00.82
2018-03-02

PHP는 sqlSrv를 사용하여 Microsoft의 SQLSERVER 데이터베이스에 연결할 때 pdo_srv 확장자를 사용해야 합니다.
pdo_srv 확장 설치는 pecl을 사용하여 직접 설치할 수 있습니다.

pecl
프로그램은 PHP 설치 디렉토리 아래의 bin 디렉토리에 있습니다. PHP 디렉토리가 Linux 환경 변수에 없는 경우. 또는 pecl 프로그램이 시스템 bin 경로에 연결되어 있지 않아 pecl 프로그램이 설치되지 않았다는 메시지가 표시됩니다.

sqlsrv를 설치하려면 unixODBC 지원이 필요하므로 설치 전에 unixODBC를 설치하지 않은 경우 unixODBC를 먼저 설치해야 하며 unixODBC는 SQLSERVER에 연결하기 위해 FreeTDS가 필요합니다. unixODBC는 일반 인터페이스 집합만 정의하고 특정 인터페이스가 없기 때문입니다. 구현 방법.

1. FreeTDS 설치
a), 다운로드

http://www.freetds.org/

b), 컴파일 및 설치

./configure --with-tdsver=auto --prefix=/usr/local/freetds --enable-msdblib --with-gnu-ld --enable-shared --enable-static --with-unixodbc=/usr/localmake
make install
로그인 후 복사
로그인 후 복사

일부 온라인 튜토리얼에서는 –with-tdsver= 8.0, 컴파일 시 오류가 발생했다고 보고했습니다. 구체적인 지원 값은 ./configure –help

에서 with-tdsver 설명을 확인하실 수 있습니다. 설치가 완료되면 /usr/local/에 etc 디렉터리가 생성됩니다. freetds.conf 파일을 사용해야 합니다.
c), 구성
freetds.conf 파일을 구성합니다.

구성할 필요가 없습니다. freetds.conf를 구성하지 않는 방법은 unixODBC

[global]#全局配置tds version = auto#更多的配置可以参考freetds官方文档,我这里这样配置已经够用了[servertag]#定义一个叫 servertag 的节点,这个节点的名称可以自定义的,不是固定#所有 # 符号的内容都可以不写在配置文件中,这里只是注释解释用#更多的细节配置看官方描述#数据库的连接IP地址host = 192.168.9.12 #数据库的端口port = 1433 #连接时默认打开的库名,【可以不配置此项】database = master 
#tds version 有全局配置,这里也可以不写tds version = auto
로그인 후 복사
로그인 후 복사

구성 링크에서 찾을 수 있습니다. 2. unixODBC 설치

a), 다운로드

  https://sourceforge.net/projects/unixodbc/files/unixODBC/
  http://www.unixodbc.org/
  以上两个网站都可以下载到,建议到第二个官网下载吧。
로그인 후 복사
로그인 후 복사

b), 컴파일 및 설치

./configure --prefix=/usr/local/unixODBC --includedir=/usr/include  --libdir=/usr/lib -bindir=/usr/bin --sysconfdir=/etcmake 
make install
로그인 후 복사
로그인 후 복사

c), 구성
/etc/odbc.ini에 구성 추가

인터넷에는 컴파일 및 설치가 /usr/local/etc/odbc.ini에 있다는 튜토리얼이 있습니다
, 이 파일은 컴파일 후에 생성되지만 이 파일의 구성은 적용되지 않습니다. /etc/odbc.ini

[ODBC Data Sources]#描述而已,没有测过不写行不行,理论上可行SQLSERVER2018912 = 9.12 DB

[SQLSERVER2018912]#Driver 指向的目录是FreeTDS编译生成的文件,类似一个驱动文件,稍后讲解安装方法Driver = /usr/local/freetds/lib/libtdsodbc.so
Description  = 9.12 DB,文字描述
Trace = No#Server 可以直接写 FreeTDS的freetds.conf 中配置的servertag节点名#使用freetds.conf配置时,port 也不用配置了。#因为在此直接写server IP时能配置的选项很少,而freetds.conf可以配置的细节更多#此处我已经配置了IP,freetds.conf中其实就可以不用配置。只要安装好freetds即可Server = 192.168.9.12Port = 1433#7.4或auto应该都可以。没有详细研究过TDS_Version = 7.4[Default]#全局默认配置。理论上可以不写#同上,默认使用Driver = /usr/local/freetds/lib/libtdsodbc.so
로그인 후 복사
로그인 후 복사

에서 구성해야 합니다. 위 구성이 완료된 후 테스트할 수 있습니다.
unixODBC 컴파일 시 생성된 isql 프로그램을 이용하여 테스트해 보세요. /usr/bin/isql

/usr/bin/isql SQLSERVER2018912 数据库账号 密码
로그인 후 복사
로그인 후 복사

isql 경로는 isql –help
를 통해 확인할 수 있다. 설정에 오류가 없다면 데이터베이스로 연결되어 있는 것을 확인할 수 있다. SQL문을 사용하여 쿼리할 수 있습니다.
unixODBC 구성이 완료되면 PHP 확장을 설치할 수 있습니다

3. PHP sqlsrv 확장 설치

pecl install sqlsrv
로그인 후 복사
로그인 후 복사

설치 후 php.ini에서 확장을 로드한 다음 아파치를 다시 시작해야 적용됩니다.
편집 후 화면에 인쇄되는 내용에 주의하세요

위 내용은 Linux에서 sqlSrv를 사용하여 PHP를 Microsoft 데이터베이스에 연결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Linux 터미널에서 Python 버전을 볼 때 발생하는 권한 문제를 해결하는 방법은 무엇입니까? Linux 터미널에서 Python 버전을 볼 때 발생하는 권한 문제를 해결하는 방법은 무엇입니까? Apr 01, 2025 pm 05:09 PM

Linux 터미널에서 Python 버전을 보려고 할 때 Linux 터미널에서 Python 버전을 볼 때 권한 문제에 대한 솔루션 ... Python을 입력하십시오 ...

Docker 환경에서 PECL을 사용하여 확장자를 설치할 때 오류가 발생하는 이유는 무엇입니까? 그것을 해결하는 방법? Docker 환경에서 PECL을 사용하여 확장자를 설치할 때 오류가 발생하는 이유는 무엇입니까? 그것을 해결하는 방법? Apr 01, 2025 pm 03:06 PM

Docker 환경을 사용할 때 Docker 환경에 Extensions를 설치하기 위해 PECL을 사용하여 오류의 원인 및 솔루션. 종종 일부 두통이 발생합니다 ...

PHP에서 늦은 정적 결합을 설명하십시오 (정적 : :). PHP에서 늦은 정적 결합을 설명하십시오 (정적 : :). Apr 03, 2025 am 12:04 AM

정적 바인딩 (정적 : :)는 PHP에서 늦은 정적 바인딩 (LSB)을 구현하여 클래스를 정의하는 대신 정적 컨텍스트에서 호출 클래스를 참조 할 수 있습니다. 1) 구문 분석 프로세스는 런타임에 수행됩니다. 2) 상속 관계에서 통화 클래스를 찾아보십시오. 3) 성능 오버 헤드를 가져올 수 있습니다.

JWT (JSON Web Tokens) 및 PHP API의 사용 사례를 설명하십시오. JWT (JSON Web Tokens) 및 PHP API의 사용 사례를 설명하십시오. Apr 05, 2025 am 12:04 AM

JWT는 주로 신분증 인증 및 정보 교환을 위해 당사자간에 정보를 안전하게 전송하는 데 사용되는 JSON을 기반으로 한 개방형 표준입니다. 1. JWT는 헤더, 페이로드 및 서명의 세 부분으로 구성됩니다. 2. JWT의 작업 원칙에는 세 가지 단계가 포함됩니다. JWT 생성, JWT 확인 및 Parsing Payload. 3. PHP에서 인증에 JWT를 사용하면 JWT를 생성하고 확인할 수 있으며 사용자 역할 및 권한 정보가 고급 사용에 포함될 수 있습니다. 4. 일반적인 오류에는 서명 검증 실패, 토큰 만료 및 대형 페이로드가 포함됩니다. 디버깅 기술에는 디버깅 도구 및 로깅 사용이 포함됩니다. 5. 성능 최적화 및 모범 사례에는 적절한 시그니처 알고리즘 사용, 타당성 기간 설정 합리적,

램프 아키텍처에서 Node.js 또는 Python 서비스를 효율적으로 통합하는 방법은 무엇입니까? 램프 아키텍처에서 Node.js 또는 Python 서비스를 효율적으로 통합하는 방법은 무엇입니까? Apr 01, 2025 pm 02:48 PM

많은 웹 사이트 개발자는 램프 아키텍처에서 Node.js 또는 Python 서비스를 통합하는 문제에 직면 해 있습니다. 기존 램프 (Linux Apache MySQL PHP) 아키텍처 웹 사이트 요구 사항 ...

php magic 방법 (__construct, __destruct, __call, __get, __set 등)이란 무엇이며 사용 사례를 제공합니까? php magic 방법 (__construct, __destruct, __call, __get, __set 등)이란 무엇이며 사용 사례를 제공합니까? Apr 03, 2025 am 12:03 AM

PHP의 마법 방법은 무엇입니까? PHP의 마법 방법은 다음과 같습니다. 1. \ _ \ _ Construct, 객체를 초기화하는 데 사용됩니다. 2. \ _ \ _ 파괴, 자원을 정리하는 데 사용됩니다. 3. \ _ \ _ 호출, 존재하지 않는 메소드 호출을 처리하십시오. 4. \ _ \ _ get, 동적 속성 액세스를 구현하십시오. 5. \ _ \ _ Set, 동적 속성 설정을 구현하십시오. 이러한 방법은 특정 상황에서 자동으로 호출되어 코드 유연성과 효율성을 향상시킵니다.

Linux 시스템에서 Python 통역사를 삭제할 수 있습니까? Linux 시스템에서 Python 통역사를 삭제할 수 있습니까? Apr 02, 2025 am 07:00 AM

Linux 시스템과 함께 제공되는 Python 통역사를 제거하는 문제와 관련하여 많은 Linux 배포판이 설치 될 때 Python 통역사를 사전 설치하고 패키지 관리자를 사용하지 않습니다 ...

See all articles