Skip to content

Zeroplex 生活隨筆

軟體開發、伺服器和生活瑣事

小 縮小字型大小。 中 重設字型大小。 大 放大字型大小。

標籤: MSSQL

透過 pdo_dblib 與 Microsoft SQL Server 連線

Posted on 2023 年 6 月 16 日2023 年 6 月 16 日 By 日落 在〈透過 pdo_dblib 與 Microsoft SQL Server 連線〉中尚無留言

除了 sqlsrv 以外,也可以透過 pdo_dblib 來連線。

若使用 ondrej 的 PHP PPA,則安裝 php-sybase,安裝後透過 php -i 可以看到 extension 資訊:

....
/etc/php/8.2/cli/conf.d/20-pdo_dblib.ini,
....
PDO drivers => dblib, mysql, pgsql, sqlite, sqlsrv

pdo_dblib

PDO Driver for FreeTDS/Sybase DB-lib => enabled
Flavour => freetds
....

寫個 script 測試連線:

<?php

$conn = new PDO(
    'dblib:host=192.168.0.7;port=1443;dbname=test;',
    'username',
    'password',
);

感謝 apmk 正太真美好 提供協助

Tags:Microsoft, MSSQL, PHP

讓 PHP 與 Microsoft SQL Server 連線

Posted on 2023 年 6 月 15 日2023 年 6 月 15 日 By 日落 在〈讓 PHP 與 Microsoft SQL Server 連線〉中尚無留言

先說,很麻煩。

需要先安裝二個驅動程式:

  • unixodbc-dev
  • Microsoft ODBC Driver for SQL Server
  • SQL Server driver for PHP

裝完以後執行 php -i,若有顯示 pdo_sqlsrv 和 sqlsrv 表示有正確啟動。

最後可參考 PHP PDO 與 SQL Server 連線的語法,建立連線。


手上的專案是跑在 Alpine Linux with PHP on Docker,這裡先做好 docker image,有需要請自取:https://hub.docker.com/repository/docker/johnroyer/php-mssql-docker/general

Tags:Microsoft, MSSQL, PHP

PHP PDO 連接 Microsoft SQL Server 時的憑證錯誤問題

Posted on 2023 年 6 月 13 日2023 年 6 月 13 日 By 日落 在〈PHP PDO 連接 Microsoft SQL Server 時的憑證錯誤問題〉中尚無留言

使用 PDO 與 SQL Server 連線時,會出現憑證錯誤的訊息:

Fatal error: Uncaught PDOException: SQLSTATE[08001]: [Microsoft][ODBC Driver 18 for SQL Server]SSL Provider: [error:0A000086:SSL routines::certificate verify failed:self-signed certificate]

是因為 SQL Server 的憑證是自己產生的,所以會被視為安全問題。

在 DSN 中設定 TrustServerCertificate 參數,可以忽略憑證錯誤:

$conn = new PDO(
    'sqlsrv:server=127.0.0.1;Database=test;TrustServerCertificate=1',
    'user',
    'password',
);
Tags:MSSQL, PHP

讓 SQL Server 支援外部連線

Posted on 2023 年 6 月 10 日2023 年 6 月 10 日 By 日落 在〈讓 SQL Server 支援外部連線〉中尚無留言

開啟 SQL Server Configuration Manager,找到「網路組態」:

SQL server config manager TCP/IP config

將「TCP/IP」選項設定為「啟用」,重新啟動 SQL server 以後,變可以透過 IP 連線到 server。

Tags:Microsoft, MSSQL

SQL Server 避免中文亂碼 (使用 Unicode)

Posted on 2021 年 12 月 23 日2023 年 6 月 10 日 By 日落 在〈SQL Server 避免中文亂碼 (使用 Unicode)〉中有 1 則留言

在 SQL server 中宣告變數為 varchar,雖然可以儲存字串,但是中文會變成亂碼。若要讓 SQL Server 可以處理多國語言的話,要記得將變數型態設定為 nvarchar:

DECLARE @str varchar(MAX);   -- 儲存一般文字

DECLARE @multibytes nvarchar(MAX);  -- 支援 unicode

另外,要設定 multibytes 字串時,記得要在引號前面加上「N」來表示字串類型:

@str = 'Hello World';   -- 一般字串

@multibytes = N'支援 multibytes 文字';  -- 引號前要加上 N

參考資料:nchar 和 nvarchar (Transact-SQL)

Tags:Microsoft, MSSQL

文章分頁

1 2 3 下一頁

其他

關於我  (About me)

小額贊助

  文章 RSS Feed

  留言 RSS Feed

Apache AWS Bash C/C++ Docker FreeBSD GCP Git Google Java JavaScript Laravel Linux Microsoft MSSQL MySQL Nginx PHP PHPUnit PostgreSQL Python Qt Ubuntu Unix Vim Web Windows WordPress XD 作業系統 分享 好站推薦 專題 攝影 新奇搞笑 新聞 旅遊 生活雜記 程式設計 網路架站 網頁設計 資訊學習 資訊安全 遊戲 音樂


創用 CC 授權條款
本著作係採用創用 CC 姓名標示-相同方式分享 4.0 國際 授權條款授權.