在 PowerShell 中使用 SQL Server 識別碼
當您搭配 Database Engine 使用適用於 Windows PowerShell 的 SQL Server 提供者時,必須提供電腦和執行個體的名稱,即使是預設執行個體也一樣。
此提供者會使用 Windows PowerShell 路徑中的 SQL Server 識別碼。SQL Server 識別碼可包含 Windows PowerShell 在路徑中不支援的字元。當您使用 Windows PowerShell 路徑中的識別碼時,您必須逸出這些字元或針對這些字元使用特殊編碼。
電腦名稱
接在 SQLSERVER:\SQL 後面的第一個節點是執行 Database Engine 執行個體的電腦名稱。例如,SQLSERVER:\SQL\MyComputer。如果您在與 Database Engine 執行個體相同的電腦上執行 Windows PowerShell,就可以使用 localhost 或 (local) 來取代電腦的名稱。使用 localhost 或 (local) 的指令碼可以在任何電腦上執行,而不需要變更成反映不同的電腦名稱。例如,這個命令將會移至本機電腦上預設執行個體中的 AdventureWorks2008R2 範例資料庫:
Set-Location SQLSERVER:\SQL\localhost\DEFAULT\Databases\AdventureWorks2008R2
(local) 中的括號字元通常會被 Windows PowerShell 視為命令。因此,您必須:
以引號括住路徑字串:
Set-Location "SQLSERVER:\SQL\(local)\DEFAULT\Databases\AdventureWorks2008R2"
使用反勾號字元 (`) 來逸出括號。
Set-Location SQLSERVER:\SQL\`(local`)\DEFAULT\Databases\AdventureWorks2008R2
使用十六進位表示法來編碼括號。
Set-Location SQLSERVER:\SQL\%28local%29\DEFAULT\Databases\AdventureWorks2008R2
本主題稍後將詳細討論逸出和編碼字元。
您不能使用句號 (.) 在 PowerShell 指令碼中指定本機電腦。因為句號會被 PowerShell 解譯成命令,所以不支援句號。
預設執行個體名稱
您可以在相同電腦上執行 Database Engine 可執行程式的多個執行個體。Database Engine 的執行個體是由電腦名稱和執行個體名稱的組合來識別,例如 MyComputer\MyInstance。
每一部電腦都只能有一個預設 Database Engine 執行個體。當您安裝預設執行個體時,未指定它的名稱。如果您在連接字串中只有指定電腦名稱,您會連接到該電腦上的預設執行個體。此電腦上的所有其他執行個體都必須是具名執行個體。您可在安裝期間指定執行個體名稱,而且連接字串必須指定電腦名稱和執行個體名稱。
SQL Server 提供者會要求您一定要指定執行個體名稱。如果是預設執行個體,您必須指定執行個體名稱 DEFAULT。
Windows PowerShell 路徑中的 SQL Server 識別碼
Windows PowerShell 提供者會使用與 Windows 檔案系統所使用之路徑結構類似的結構來公開資料階層。SQL Server 提供者會實作 SQL Server 物件的路徑。如果是 Database Engine,磁碟機會設定為 SQLSERVER:、第一個資料夾會設定為 \SQL,而且資料庫物件會當做容器和項目來參考。這是預設 Database Engine 執行個體中 AdventureWorks2008R2 資料庫之 Purchasing 結構描述的 Vendor 資料表路徑:
SQLSERVER:\SQL\MyComputer\DEFAULT\Databases\AdventureWorks2008R2\Tables\Purchasing.Vendor
SQL Server 識別碼為 SQL Server 物件的名稱,例如資料表或資料行名稱。SQL Server 識別碼有兩種:
一般識別碼限制為 Windows PowerShell 路徑中也支援的一組字元。這些名稱可以在 Windows PowerShell 路徑中使用,而不需變更。
分隔識別碼可以使用 Windows PowerShell 路徑名稱中不支援的字元。分隔識別碼如果放在括號內 ([IdentifierName]),則稱為括號識別碼,而如果是放在雙引號內 ("IdentifierName"),則稱為引號識別碼。如果分隔識別碼使用 Windows PowerShell 路徑中不支援的字元,這些字元必須先編碼或逸出,然後才可以使用該識別碼當做容器或項目名稱。編碼適用於所有字元。某些字元 (例如冒號字元 (:)) 無法逸出。
編碼及解碼識別碼
Windows PowerShell 路徑名稱中不支援的字元可以表示或編碼為 "%" 字元,後面緊接著代表此字元之位元模式的十六進位值,就像是 "**%**xx"。編碼一定可以用來處理 Windows PowerShell 路徑中不支援的字元。
Encode-SqlName 指令程式會將 SQL Server 識別碼當做輸入。它會輸出一個字串,其中包含編碼為 "%xx" 之 Windows PowerShell 語言不支援的所有字元。Decode-SqlName 指令程式會將編碼的 SQL Server 識別碼當做輸入,並傳回原始識別碼。例如:
這個命令會傳回 "Table%3ATest" 字串:
Encode-SqlName "Table:Test"
這個命令會傳回 "Table:Test":
Decode-SqlName "Table%3ATest"
當您在 Windows PowerShell 指令程式中指定分隔識別碼時,您可以自己提供編碼字元,或是使用 Encode-SqlName 提供編碼字元。例如,如果您已經導覽至包含 [Table:Test] 資料表的結構描述,您可以提供編碼版本的 ":" 字元來 cd 至此資料表:
Set-Location Table%3ATest
另外,您也可以使用 Encode-SqlName 來建立 Windows PowerShell 所支援的名稱:
Set-Location (Encode-SqlName "Table:Test")
這些是由 Encode-SqlName 所編碼並由 Decode-SqlName 所解碼的字元:
字元 |
\ |
/ |
: |
% |
< |
> |
* |
? |
[ |
] |
| |
十六進位編碼 |
%5C |
%2F |
%3A |
%25 |
%3C |
%3E |
%2A |
%3F |
%5B |
%5D |
%7C |
逸出字元
您可以經常使用 Windows PowerShell 反勾號逸出字元 (`) 來逸出 SQL Server 分隔識別碼中所允許,但是 Windows PowerShell 路徑名稱所不允許的字元。但是,某些字元無法逸出。例如,您無法逸出 Windows PowerShell 中的冒號字元 (:)。具有該字元的識別碼必須加以編碼。編碼比逸出更為可靠,因為編碼適用於所有字元。
這是逸出 # 字元的範例:
cd SQLSERVER:\SQL\MyComputer\MyInstance\MyDatabase\MySchema\`#MyTempTable
反勾號字元 (`) 通常是在鍵盤左上方 ESC 鍵底下的按鍵上。
指令程式中的 SQL Server 識別碼
某些 SQL Server 指令程式有一個參數會將識別碼當做輸入。參數值通常會以加上引號的字串常數形式提供,或是在字串變數中提供。當以字串常數的形式或是在變數中提供識別碼時,不會與 Windows PowerShell 支援的字元集合發生衝突。