Linux에서 sqlSrv를 사용하여 PHP를 Microsoft 데이터베이스에 연결하는 방법
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제









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

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

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

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

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

Linux 터미널에서 Python 사용 ...

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

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