共用方式為


快速入門:使用 Docker 執行 SQL Server Linux 容器映像

適用於:SQL Server - Linux

在本快速入門中,您將使用 Docker 來提取和執行 SQL Server 2017 (14.x) Linux 容器映像,mssql-server-linux。 接著,您可以使用 sqlcmd 連線以建立您的第一個資料庫並執行查詢。

如需支援平台的詳細資訊,請參閱 Linux 上 SQL Server 2017 的版本資訊

警告

停止及移除容器時,容器中的 SQL Server 資料會永久刪除。 如需保留資料的詳細資訊,請建立備份檔案並複製到容器外,或使用容器資料持續性技術

本快速入門會建立 SQL Server 2017 (14.x) 容器。 如果您想為不同版本的 SQL Server 建立 Linux 容器,請參閱本文的 SQL Server 2019 (15.x)SQL Server 2022 (16.x) 版本。

在本快速入門中,您將使用 Docker 來提取和執行 SQL Server 2019 (15.x) Linux 容器映像,mssql-server-linux。 接著,您可以使用 sqlcmd 連線以建立您的第一個資料庫並執行查詢。

如需支援平台的詳細資訊,請參閱 Linux 上 SQL Server 2019 的版本資訊

警告

停止及移除容器時,容器中的 SQL Server 資料會永久刪除。 如需保留資料的詳細資訊,請建立備份檔案並複製到容器外,或使用容器資料持續性技術

本快速入門會建立 SQL Server 2019 (15.x) 容器。 如果您想要為不同版本的 SQL Server 建立 Linux 容器,請參閱本文的 SQL Server 2017 (14.x)SQL Server 2022 (16.x) 版本。

在本快速入門中,您將使用 Docker 來提取和執行 SQL Server 2022 (16.x) Linux 容器映像,mssql-server-linux。 接著,您可以使用 sqlcmd 連線以建立您的第一個資料庫並執行查詢。

如需支援平台的詳細資訊,請參閱 Linux 上 SQL Server 2022 的版本資訊

警告

停止及移除容器時,容器中的 SQL Server 資料會永久刪除。 如需保留資料的詳細資訊,請建立備份檔案並複製到容器外,或使用容器資料持續性技術

本快速入門會建立 SQL Server 2022 (16.x) 容器。 如果您想要為不同版本的 SQL Server 建立 Linux 容器,請參閱本文的 SQL Server 2017 (14.x)SQL Server 2019 (15.x) 版本。

此映像包含以 Ubuntu 為基礎,在 Linux 上執行的 SQL Server。 您可以在 Linux 上將其與 Docker 引擎 1.8 以上版本搭配使用。

在 SQL Server 2022 (16.x) CU 14 和更新版本中,容器映射包含全新 mssql-tools18 套件。 上一個目錄 /opt/mssql-tools/bin 正在逐步淘汰。Microsoft ODBC 18 工具的全新目錄是 /opt/mssql-tools18/bin,與最新的工具供應專案一致。 如需變更和安全性增強功能的詳細資訊,請參閱 ODBC 驅動程式 18.0 for SQL Server Released

本文中的範例使用 docker 命令。 不過,多數命令也適用於 Podman。 Podman 提供類似於 Docker 引擎的命令列介面。 您可以進一步了解 Podman

重要

sqlcmd 目前不支援建立容器時的 MSSQL_PID 參數。 如果您使用本快速入門中的 sqlcmd 指示,請使用 SQL Server 開發人員版本來建立容器。 使用命令列介面 (CLI) 指示,以使用您選擇的授權來建立容器。 如需詳細資訊,請參閱部署和連線到 SQL Server Linux 容器

必要條件

  • 任何支援的 Linux 發行版本上的 Docker 引擎 1.8 以上版本。 如需詳細資訊,請參閱安裝 Docker

提取並執行 SQL Server Linux 容器映像

開始下列步驟之前,請確定您已在本文頂端選取您慣用的 Shell (BashPowerShellcmd)。

本文中的 Bash 命令會使用 sudo。 如果您不想使用 sudo 來執行 Docker,您可以設定 docker 群組,並將使用者新增至該群組。 如需詳細資訊,請參閱 Post-installation steps for Linux (適用於 Linux 的安裝後步驟)。

從登錄提取容器

從 Microsoft Container Registry 提取 SQL Server 2017 (14.x) Linux 容器映像。

sudo docker pull mcr.microsoft.com/mssql/server:2017-latest
docker pull mcr.microsoft.com/mssql/server:2017-latest
docker pull mcr.microsoft.com/mssql/server:2017-latest

本快速入門會建立 SQL Server 2017 (14.x) 容器。 如果您想要為不同版本的 SQL Server 建立 Linux 容器,請參閱本文的 SQL Server 2019 (15.x)SQL Server 2022 (16.x) 版本。

上述命令會提取最新的 SQL Server 2017 (14.x) Linux 容器映像。 若要提取特定映像,您需要新增欄位與標籤名稱,例如 mcr.microsoft.com/mssql/server:2017-GA-ubuntu。 若要查看所有可用的映像,請參閱 Microsoft 成品登錄

執行容器

若要以 Docker 執行 Linux 容器映像,您可以從 Bash 殼層或提高權限的 PowerShell 命令提示字元使用下列命令。

重要

SA_PASSWORD 環境變數已被取代。 請改用 MSSQL_SA_PASSWORD

sudo docker run -e "ACCEPT_EULA=Y" -e "MSSQL_SA_PASSWORD=<password>" \
   -p 1433:1433 --name sql1 --hostname sql1 \
   -d \
   mcr.microsoft.com/mssql/server:2017-latest

如果正在使用 PowerShell Core,請將雙引號取代為單引號。

docker run -e "ACCEPT_EULA=Y" -e "MSSQL_SA_PASSWORD=<password>" `
   -p 1433:1433 --name sql1 --hostname sql1 `
   -d `
   mcr.microsoft.com/mssql/server:2017-latest
docker run -e "ACCEPT_EULA=Y" -e "MSSQL_SA_PASSWORD=<password>" `
   -p 1433:1433 --name sql1 --hostname sql1 `
   -d `
   mcr.microsoft.com/mssql/server:2017-latest

警告

您的密碼應遵循 SQL Server 預設 密碼原則。 依預設,密碼長度必須至少有 8 個字元,並包含下列四種字元組合中其中三種組合的字元:大寫字母、小寫字母、以 10 為底數的數字以及符號。 密碼長度最多可達 128 個字元。 盡可能使用長且複雜的密碼。 如果您未遵循這些密碼需求,容器就無法設定 SQL Server 並停止運作。 使用 docker logs 命令即可查看錯誤記錄。

依預設,此快速入門會建立 SQL Server Developer 版本的容器。 在容器中執行生產版本的程序將有些微差異。 如需詳細資訊,請參閱執行生產容器映像

下表提供了前述 docker run 範例的參數描述:

參數 描述
-e "ACCEPT_EULA=Y" ACCEPT_EULA 變數設為任意值可確認您接受終端使用者授權合約。 此為 SQL Server 映像的必要設定。
-e "MSSQL_SA_PASSWORD=<password>" 指定您自己的強式密碼,該密碼長度至少需為八個字元且符合密碼原則。 此為 SQL Server 映像的必要設定。
-e "MSSQL_COLLATION=<SQL_Server_collation>" 指定自訂 SQL Server 定序,而非預設 SQL_Latin1_General_CP1_CI_AS
-p 1433:1433 將主機環境上的 TCP 連接埠 (第一個值) 對應至容器中的 TCP 連接埠 (第二個值)。 在本範例中,SQL Server 正在接聽容器中的 TCP 1433,且此容器連接埠接著會對主機上的 TCP 連接埠 1433 公開。
--name sql1 為容器指定自訂名稱,而不使用隨機產生的名稱。 若您執行數個容器,便無法重複使用此相同名稱。
--hostname sql1 用來明確設定容器主機名稱。 如果您未指定主機名稱,則會預設為隨機產生之系統 GUID 的容器識別碼。
-d 在背景執行容器 (精靈)。
mcr.microsoft.com/mssql/server:2017-latest SQL Server Linux 容器映像。

檢視容器清單

  1. 若要檢視 Docker 容器,請使用 docker ps 命令。

    sudo docker ps -a
    
    docker ps -a
    
    docker ps -a
    

    您應該會看到類似下列範例的結果:

    CONTAINER ID   IMAGE                                        COMMAND                    CREATED         STATUS         PORTS                                       NAMES
    d4a1999ef83e   mcr.microsoft.com/mssql/server:2017-latest   "/opt/mssql/bin/perm..."   2 minutes ago   Up 2 minutes   0.0.0.0:1433->1433/tcp, :::1433->1433/tcp   sql1
    
  2. STATUS 欄位顯示的狀態含 Up,表示 SQL Server 正在容器中執行且接聽於 PORTS 欄位中指定的連接埠。 如果 SQL Server 容器的 STATUS 欄顯示 Exited,請參閱對 SQL Server Docker 容器進行疑難排解。 一旦 SQL Server 錯誤記錄檔顯示下列訊息,表示伺服器已準備好進行連線:SQL Server is now ready for client connections. This is an informational message; no user action is required。 您可以使用下列命令,在容器內檢閱 SQL Server 錯誤記錄檔:

    sudo docker exec -t sql1 cat /var/opt/mssql/log/errorlog | grep connection
    

    先前討論的 --hostname 參數可將容器的內部名稱變更為自訂值。 此值是您在下列 Transact-SQL 查詢中會看到的傳回名稱:

    SELECT @@SERVERNAME,
           SERVERPROPERTY('ComputerNamePhysicalNetBIOS'),
           SERVERPROPERTY('MachineName'),
           SERVERPROPERTY('ServerName');
    

    建議您將 --hostname--name 設為相同的值,這會讓識別目標容器更輕鬆。

  3. 因為 MSSQL_SA_PASSWORD 會顯示在 ps -eax 輸出中,且儲存在相同名稱的環境變數中,所以實際執行環境中的最後一個步驟是變更您的 SA 密碼

提取並執行 SQL Server Linux 容器映像

開始下列步驟之前,請確定您已在本文頂端選取您慣用的 Shell (BashPowerShellcmd)。

本文中的 Bash 命令會使用 sudo。 如果您不想使用 sudo 來執行 Docker,您可以設定 docker 群組,並將使用者新增至該群組。 如需詳細資訊,請參閱 Post-installation steps for Linux (適用於 Linux 的安裝後步驟)。

從登錄提取容器

從 Microsoft Container Registry 提取 SQL Server 2019 (15.x) Linux 容器映像。

docker pull mcr.microsoft.com/mssql/server:2019-latest
docker pull mcr.microsoft.com/mssql/server:2019-latest
docker pull mcr.microsoft.com/mssql/server:2019-latest

本快速入門會建立 SQL Server 2019 (15.x) 容器。 如果您想要為不同版本的 SQL Server 建立 Linux 容器,請參閱本文的 SQL Server 2017 (14.x)SQL Server 2022 (16.x) 版本。

上述命令會提取最新的 SQL Server 2019 (15.x) Linux 容器映像。 若要提取特定映像,您需要新增欄位與標籤名稱,例如 mcr.microsoft.com/mssql/server:2019-GA-ubuntu。 若要查看所有可用的映像,請參閱 Microsoft 成品登錄

執行容器

若要以 Docker 執行 Linux 容器映像,您可以從 Bash 殼層或提高權限的 PowerShell 命令提示字元使用下列命令。

重要

SA_PASSWORD 環境變數已被取代。 請改用 MSSQL_SA_PASSWORD

docker run -e "ACCEPT_EULA=Y" -e "MSSQL_SA_PASSWORD=<password>" \
   -p 1433:1433 --name sql1 --hostname sql1 \
   -d \
   mcr.microsoft.com/mssql/server:2019-latest

如果正在使用 PowerShell Core,請將雙引號取代為單引號。

docker run -e "ACCEPT_EULA=Y" -e "MSSQL_SA_PASSWORD=<password>" `
   -p 1433:1433 --name sql1 --hostname sql1 `
   -d `
   mcr.microsoft.com/mssql/server:2019-latest

警告

您的密碼應遵循 SQL Server 預設 密碼原則。 依預設,密碼長度必須至少有 8 個字元,並包含下列四種字元組合中其中三種組合的字元:大寫字母、小寫字母、以 10 為底數的數字以及符號。 密碼長度最多可達 128 個字元。 盡可能使用長且複雜的密碼。

docker run -e "ACCEPT_EULA=Y" -e "MSSQL_SA_PASSWORD=<password>" `
   -p 1433:1433 --name sql1 --hostname sql1 `
   -d `
   mcr.microsoft.com/mssql/server:2019-latest

警告

您的密碼應遵循 SQL Server 預設 密碼原則。 依預設,密碼長度必須至少有 8 個字元,並包含下列四種字元組合中其中三種組合的字元:大寫字母、小寫字母、以 10 為底數的數字以及符號。 密碼長度最多可達 128 個字元。 盡可能使用長且複雜的密碼。 如果您未遵循這些密碼需求,容器就無法設定 SQL Server 並停止運作。 使用 docker logs 命令即可查看錯誤記錄。

依預設,此快速入門會建立 SQL Server Developer 版本的容器。 在容器中執行生產版本的程序將有些微差異。 如需詳細資訊,請參閱執行生產容器映像

下表提供了前述 docker run 範例的參數描述:

參數 描述
-e "ACCEPT_EULA=Y" ACCEPT_EULA 變數設為任意值可確認您接受終端使用者授權合約。 此為 SQL Server 映像的必要設定。
-e "MSSQL_SA_PASSWORD=<password>" 指定您自己的強式密碼,該密碼長度至少需為八個字元且符合密碼原則。 此為 SQL Server 映像的必要設定。
-e "MSSQL_COLLATION=<SQL_Server_collation>" 指定自訂 SQL Server 定序,而非預設 SQL_Latin1_General_CP1_CI_AS
-p 1433:1433 將主機環境上的 TCP 連接埠 (第一個值) 對應至容器中的 TCP 連接埠 (第二個值)。 在本範例中,SQL Server 正在接聽容器中的 TCP 1433,且此容器連接埠接著會對主機上的 TCP 連接埠 1433 公開。
--name sql1 為容器指定自訂名稱,而不使用隨機產生的名稱。 若您執行數個容器,便無法重複使用此相同名稱。
--hostname sql1 用來明確設定容器主機名稱。 如果您未指定主機名稱,則會預設為隨機產生之系統 GUID 的容器識別碼。
-d 在背景執行容器 (精靈)。
mcr.microsoft.com/mssql/server:2019-latest SQL Server Linux 容器映像。

檢視容器清單

  1. 若要檢視 Docker 容器,請使用 docker ps 命令。

    docker ps -a
    
    docker ps -a
    
    docker ps -a
    

    您應該會看到類似下列範例的結果:

    CONTAINER ID   IMAGE                                        COMMAND                    CREATED         STATUS         PORTS                                       NAMES
    d4a1999ef83e   mcr.microsoft.com/mssql/server:2019-latest   "/opt/mssql/bin/perm..."   2 minutes ago   Up 2 minutes   0.0.0.0:1433->1433/tcp, :::1433->1433/tcp   sql1
    
  2. STATUS 欄位顯示的狀態含 Up,表示 SQL Server 正在容器中執行且接聽於 PORTS 欄位中指定的連接埠。 如果 SQL Server 容器的 STATUS 欄顯示 Exited,請參閱對 SQL Server Docker 容器進行疑難排解。 一旦 SQL Server 錯誤記錄檔顯示下列訊息,表示伺服器已準備好進行連線:SQL Server is now ready for client connections. This is an informational message; no user action is required。 您可以使用下列命令,在容器內檢閱 SQL Server 錯誤記錄檔:

    docker exec -t sql1 cat /var/opt/mssql/log/errorlog | grep connection
    

    先前討論的 --hostname 參數可將容器的內部名稱變更為自訂值。 此值是您在下列 Transact-SQL 查詢中會看到的傳回名稱:

    SELECT @@SERVERNAME,
           SERVERPROPERTY('ComputerNamePhysicalNetBIOS'),
           SERVERPROPERTY('MachineName'),
           SERVERPROPERTY('ServerName');
    

    建議您將 --hostname--name 設為相同的值,這會讓識別目標容器更輕鬆。

  3. 因為 MSSQL_SA_PASSWORD 會顯示在 ps -eax 輸出中,且儲存在相同名稱的環境變數中,所以實際執行環境中的最後一個步驟是變更您的 SA 密碼

提取並執行 SQL Server Linux 容器映像

開始下列步驟之前,請確定您已在本文頂端選取您慣用的 Shell (BashPowerShellcmd)。

本文中的 Bash 命令會使用 sudo。 如果您不想使用 sudo 來執行 Docker,您可以設定 docker 群組,並將使用者新增至該群組。 如需詳細資訊,請參閱 Post-installation steps for Linux (適用於 Linux 的安裝後步驟)。

從登錄提取容器

從 Microsoft Container Registry 提取 SQL Server 2022 (16.x) Linux 容器映像。

docker pull mcr.microsoft.com/mssql/server:2022-latest
docker pull mcr.microsoft.com/mssql/server:2022-latest
docker pull mcr.microsoft.com/mssql/server:2022-latest

本快速入門會建立 SQL Server 2022 (16.x) 容器。 如果您想要為不同版本的 SQL Server 建立 Linux 容器,請參閱本文的 SQL Server 2017 (14.x)SQL Server 2019 (15.x) 版本。

上述命令會提取最新的 SQL Server 2022 (16.x) Linux 容器映像。 若要提取特定映像,您需要新增欄位與標籤名稱,例如 mcr.microsoft.com/mssql/server:2022-GA-ubuntu。 若要查看所有可用的映像,請參閱 Microsoft 成品登錄

執行容器

若要以 Docker 執行 Linux 容器映像,您可以從 Bash 殼層或提高權限的 PowerShell 命令提示字元使用下列命令。

重要

SA_PASSWORD 環境變數已被取代。 請改用 MSSQL_SA_PASSWORD

docker run -e "ACCEPT_EULA=Y" -e "MSSQL_SA_PASSWORD=<password>" \
   -p 1433:1433 --name sql1 --hostname sql1 \
   -d \
   mcr.microsoft.com/mssql/server:2022-latest

如果正在使用 PowerShell Core,請將雙引號取代為單引號。

docker run -e "ACCEPT_EULA=Y" -e "MSSQL_SA_PASSWORD=<password>" `
   -p 1433:1433 --name sql1 --hostname sql1 `
   -d `
   mcr.microsoft.com/mssql/server:2022-latest
docker run -e "ACCEPT_EULA=Y" -e "MSSQL_SA_PASSWORD=<password>" `
   -p 1433:1433 --name sql1 --hostname sql1 `
   -d `
   mcr.microsoft.com/mssql/server:2022-latest

警告

您的密碼應遵循 SQL Server 預設 密碼原則。 依預設,密碼長度必須至少有 8 個字元,並包含下列四種字元組合中其中三種組合的字元:大寫字母、小寫字母、以 10 為底數的數字以及符號。 密碼長度最多可達 128 個字元。 盡可能使用長且複雜的密碼。 如果您未遵循這些密碼需求,容器就無法設定 SQL Server 並停止運作。 使用 docker logs 命令即可查看錯誤記錄。

依預設,此快速入門會建立 SQL Server Developer 版本的容器。 在容器中執行生產版本的程序將有些微差異。 如需詳細資訊,請參閱執行生產容器映像

下表提供了前述 docker run 範例的參數描述:

參數 描述
-e "ACCEPT_EULA=Y" ACCEPT_EULA 變數設為任意值可確認您接受終端使用者授權合約。 此為 SQL Server 映像的必要設定。
-e "MSSQL_SA_PASSWORD=<password>" 指定您自己的強式密碼,該密碼長度至少需為八個字元且符合密碼原則。 此為 SQL Server 映像的必要設定。
-e "MSSQL_COLLATION=<SQL_Server_collation>" 指定自訂 SQL Server 定序,而非預設 SQL_Latin1_General_CP1_CI_AS
-p 1433:1433 將主機環境上的 TCP 連接埠 (第一個值) 對應至容器中的 TCP 連接埠 (第二個值)。 在本範例中,SQL Server 正在接聽容器中的 TCP 1433,且此容器連接埠接著會對主機上的 TCP 連接埠 1433 公開。
--name sql1 為容器指定自訂名稱,而不使用隨機產生的名稱。 若您執行數個容器,便無法重複使用此相同名稱。
--hostname sql1 用來明確設定容器主機名稱。 如果您未指定主機名稱,則會預設為隨機產生之系統 GUID 的容器識別碼。
-d 在背景執行容器 (精靈)。
mcr.microsoft.com/mssql/server:2022-latest SQL Server Linux 容器映像。

變更系統管理員密碼

系統管理員 (sa) 帳戶是安裝期間建立之 SQL Server 實例上的系統管理員。 在您建立 SQL Server 容器之後,在容器中執行 echo $MSSQL_SA_PASSWORD,即可探索您指定的 MSSQL_SA_PASSWORD 環境變數。 基於安全性考慮,您應該在生產環境中變更密碼 sa

  1. 選擇要用於帳戶的 sa 強密碼。 您的密碼應遵循 SQL Server 預設 密碼原則。 依預設,密碼長度必須至少有 8 個字元,並包含下列四種字元組合中其中三種組合的字元:大寫字母、小寫字母、以 10 為底數的數字以及符號。 密碼長度最多可達 128 個字元。 盡可能使用長且複雜的密碼。

  2. 使用 docker exec 來執行 sqlcmd,以使用 Transact-SQL 變更密碼。 在下列範例中,系統會從使用者輸入讀取舊密碼和新密碼。

    docker exec -it sql1 /opt/mssql-tools18/bin/sqlcmd \
    -S localhost -U sa \
     -P "$(read -sp "Enter current SA password: "; echo "${REPLY}")" \
     -Q "ALTER LOGIN sa WITH PASSWORD=\"$(read -sp "Enter new SA password: "; echo "${REPLY}")\""
    
    docker exec -it sql1 /opt/mssql-tools18/bin/sqlcmd `
       -S localhost -U sa -P "<password>" `
       -Q "ALTER LOGIN sa WITH PASSWORD='<new-password>'"
    
    docker exec -it sql1 /opt/mssql-tools18/bin/sqlcmd `
       -S localhost -U sa -P "<password>" `
       -Q "ALTER LOGIN sa WITH PASSWORD='<new-password>'"
    

    警告

    您的密碼應遵循 SQL Server 預設 密碼原則。 依預設,密碼長度必須至少有 8 個字元,並包含下列四種字元組合中其中三種組合的字元:大寫字母、小寫字母、以 10 為底數的數字以及符號。 密碼長度最多可達 128 個字元。 盡可能使用長且複雜的密碼。

    最新版本的 sqlcmd 預設為安全。 如需連線加密的詳細資訊,請參閱適用於 Windows 的 sqlcmd 公用程式,以及適用於 Linux 和 macOS 的使用 sqlcmd 進行連線。 如果連線不成功,您可以將 -No 選項新增至 sqlcmd,以指定加密是選擇性的,而不是強制性的。

停用 SA 帳戶作為最佳做法

重要

您需要這些認證來執行後續步驟。 請務必記下您在此處輸入的使用者識別碼和密碼。

當您在安裝后第一次使用系統管理員 (sa) 帳戶連線到 SQL Server 實例時,請務必遵循這些步驟,然後立即停用 sa 帳戶作為安全性最佳做法。

  1. 建立新的登入,並將其設為 sysadmin 伺服器角色的成員。

  2. 使用您建立的新登入,連線至 SQL Server 執行個體。

  3. 建議的安全性最佳做法為停用 sa 帳戶。

檢視容器清單

  1. 若要檢視 Docker 容器,請使用 docker ps 命令。

    docker ps -a
    
    docker ps -a
    
    docker ps -a
    

    您應該會看到類似下列範例的結果:

    CONTAINER ID   IMAGE                                        COMMAND                    CREATED         STATUS         PORTS                                       NAMES
    d4a1999ef83e   mcr.microsoft.com/mssql/server:2022-latest   "/opt/mssql/bin/perm..."   2 minutes ago   Up 2 minutes   0.0.0.0:1433->1433/tcp, :::1433->1433/tcp   sql1
    
  2. STATUS 欄位顯示的狀態含 Up,表示 SQL Server 正在容器中執行且接聽於 PORTS 欄位中指定的連接埠。 如果 SQL Server 容器的 STATUS 欄顯示 Exited,請參閱對 SQL Server Docker 容器進行疑難排解。 一旦 SQL Server 錯誤記錄檔顯示下列訊息,表示伺服器已準備好進行連線:SQL Server is now ready for client connections. This is an informational message; no user action is required。 您可以使用下列命令,在容器內檢閱 SQL Server 錯誤記錄檔:

    docker exec -t sql1 cat /var/opt/mssql/log/errorlog | grep connection
    

    先前討論的 --hostname 參數可將容器的內部名稱變更為自訂值。 此值是您在下列 Transact-SQL 查詢中會看到的傳回名稱:

    SELECT @@SERVERNAME,
           SERVERPROPERTY('ComputerNamePhysicalNetBIOS'),
           SERVERPROPERTY('MachineName'),
           SERVERPROPERTY('ServerName');
    

    建議您將 --hostname--name 設為相同的值,這會讓識別目標容器更輕鬆。

連接至 SQL Server

下列步驟會在容器中使用 SQL Server 命令列工具 sqlcmd 公用程式以連線至 SQL Server。

  1. 使用 docker exec -it 命令在您執行的容器中啟動互動式 Bash 殼層。 在下列範例中,sql1 是您在建立容器時由 --name 參數指定的名稱。

    docker exec -it sql1 "bash"
    
    docker exec -it sql1 "bash"
    
    docker exec -it sql1 "bash"
    
  1. 進入容器後,以 sqlcmd 並使用其完整路徑進行本機連線。

    /opt/mssql-tools/bin/sqlcmd -S localhost -U <userid> -P "<password>"
    

    最新版本的 sqlcmd 預設為安全。 如需連線加密的詳細資訊,請參閱適用於 Windows 的 sqlcmd 公用程式,以及適用於 Linux 和 macOS 的使用 sqlcmd 進行連線。 如果連線不成功,您可以將 -No 選項新增至 sqlcmd,以指定加密是選用的,而不是強制性的。

    您可以在命令列中省略密碼,不要在提示時輸入密碼。 例如:

    /opt/mssql-tools/bin/sqlcmd -S localhost -U <userid>
    
  1. 進入容器後,以 sqlcmd 並使用其完整路徑進行本機連線。

    /opt/mssql-tools18/bin/sqlcmd -S localhost -U <userid> -P "<password>"
    

    最新版本的 sqlcmd 預設為安全。 如需連線加密的詳細資訊,請參閱適用於 Windows 的 sqlcmd 公用程式,以及適用於 Linux 和 macOS 的使用 sqlcmd 進行連線。 如果連線不成功,您可以將 -No 選項新增至 sqlcmd,以指定加密是選用的,而不是強制性的。

    您可以在命令列中省略密碼,不要在提示時輸入密碼。 例如:

    /opt/mssql-tools18/bin/sqlcmd -S localhost -U <userid>
    
  1. 進入容器後,以 sqlcmd 並使用其完整路徑進行本機連線。

    /opt/mssql-tools18/bin/sqlcmd -S localhost -U <userid> -P "<password>"
    

    最新版本的 sqlcmd 預設為安全。 如需連線加密的詳細資訊,請參閱適用於 Windows 的 sqlcmd 公用程式,以及適用於 Linux 和 macOS 的使用 sqlcmd 進行連線。 如果連線不成功,您可以將 -No 選項新增至 sqlcmd,以指定加密是選用的,而不是強制性的。

    您可以在命令列中省略密碼,不要在提示時輸入密碼。 例如:

    /opt/mssql-tools18/bin/sqlcmd -S localhost -U <userid>
    
  1. 如果成功,您應該會收到 sqlcmd 命令提示字元:1>

建立及查詢資料

下列各節將逐步引導使用 sqlcmd 和 Transact-SQL 來建立新資料庫、新增資料及執行查詢。

建立新資料庫

下列步驟會建立名為 TestDB 的新資料庫。

  1. sqlcmd 命令提示字元,貼上下列 Transact-SQL 命令以建立測試資料庫:

    CREATE DATABASE TestDB;
    
  2. 在下一行,撰寫查詢以傳回您伺服器上所有資料庫的名稱:

    SELECT name
    FROM sys.databases;
    
  3. 先前的兩個命令並未立即執行。 在新的一行上鍵入 GO 來執行先前命令:

    GO
    

插入資料

接下來,建立新的資料表 Inventory,然後插入兩個新的資料列。

  1. sqlcmd 命令提示字元,將內容切換至 TestDB 資料庫:

    USE TestDB;
    
  2. 建立名為 Inventory 的新資料表:

    CREATE TABLE Inventory
    (
        id INT,
        name NVARCHAR (50),
        quantity INT
    );
    
  3. 將資料插入新的資料表:

    INSERT INTO Inventory
    VALUES (1, 'banana', 150);
    
    INSERT INTO Inventory
    VALUES (2, 'orange', 154);
    
  4. 鍵入 GO 來執行先前命令:

    GO
    

選取資料

現在,執行查詢以從 Inventory 資料表傳回資料。

  1. sqlcmd 命令提示字元,輸入查詢以從 Inventory 資料表傳回 quantity (數量) 大於 152 的資料列:

    SELECT *
    FROM Inventory
    WHERE quantity > 152;
    
  2. 執行命令:

    GO
    

結束 sqlcmd 命令提示字元

  1. 若要結束您的 sqlcmd 工作階段,請鍵入 QUIT

    QUIT
    
  2. 若要結束容器中的互動式命令提示字元,請鍵入 exit。 結束互動式 Bash 殼層後,容器會繼續執行。

從容器外部連線

您也可以從支援 SQL 連線的任何外部 Linux、Windows 或 macOS 工具連線到 Docker 機器上的 SQL Server 執行個體。 外部工具會使用主機電腦的 IP 位址。

下列步驟在您容器的外部使用了 sqlcmd 以連線至容器中執行的 SQL Server。 這些步驟會假設您已經在容器外部安裝 SQL Server 命令列工具。 使用其他工具時亦適用相同原則,但各工具的連線程序不盡相同。

  1. 使用 ifconfigip addr 以尋找容器主機電腦的 IP 位址。

  2. 針對此範例,請在您的用戶端電腦上安裝 sqlcmd 工具。 如需詳細資訊,請參閱 sqlcmd 公用程式在 Linux 上安裝 SQL Server 命令列工具 sqlcmd 和 bcp

  3. 執行 sqlcmd 來指定 IP 位址,以及對應至您容器連接埠 1433 的連接埠。 在此範例中,連接埠即為主機電腦上的相同連接埠 1433。 如果您在主機電腦上指定了不同的對應連接埠,您可以在這裡使用該連接埠。 您也將需要在防火牆上開啟適當的輸入連接埠來允許連線。

    最新版本的 sqlcmd 預設為安全。 如果連線不成功,且使用的是第 18 版或更高版本,您可以將 -No 選項新增至 sqlcmd,以指定加密是選用的,而不是強制性的。

    sudo sqlcmd -S <ip_address>,1433 -U <userid> -P "<password>"
    
    sqlcmd -S <ip_address>,1433 -U <userid> -P "<password>"
    
    sqlcmd -S <ip_address>,1433 -U <userid> -P "<password>"
    

    警告

    您的密碼應遵循 SQL Server 預設 密碼原則。 依預設,密碼長度必須至少有 8 個字元,並包含下列四種字元組合中其中三種組合的字元:大寫字母、小寫字母、以 10 為底數的數字以及符號。 密碼長度最多可達 128 個字元。 盡可能使用長且複雜的密碼。

  4. 執行 Transact-SQL 命令。 完成後,鍵入 QUIT

其他常用的 SQL Server 連線工具包括:

移除容器

若要移除本教學課程中用到的 SQL Server 容器,請執行下列命令:

docker stop sql1
docker rm sql1
docker stop sql1
docker rm sql1
docker stop sql1
docker rm sql1

Dock 示範

在您使用完適用於 Docker 的 SQL Server Linux 容器映像後,或許會想要了解如何使用 Docker 來改善開發與測試。 下方影片會示範如何在持續整合與部署案例中使用 Docker。

參與編輯 SQL 文件

您知道您可以自行編輯 SQL 內容嗎? 這樣做不僅可以協助改善文件,也能名列該頁面的參與者。

如需詳細資訊,請參閱如何參與 SQL Server 文件