msiSetFeatureStateW 函式 (msiquery.h)
MsiSetFeatureState 函式會將功能設定為指定的狀態。
語法
UINT MsiSetFeatureStateW(
[in] MSIHANDLE hInstall,
[in] LPCWSTR szFeature,
[in] INSTALLSTATE iState
);
參數
[in] hInstall
處理提供給 DLL 自定義動作的安裝,或透過 MsiOpenPackage、 MsiOpenPackageEx 或 MsiOpenProduct 取得。
[in] szFeature
指定功能的名稱。
[in] iState
指定要設定的狀態。 此參數可以是下列其中一個值。
值 | 意義 |
---|---|
|
未安裝此功能。 |
|
此功能安裝在本機磁碟驅動器上。 |
|
此功能是從來源、CD 或網路執行。 |
|
此功能已公告。 |
傳回值
MsiSetFeatureState 函式會傳回下列值:
備註
MsiSetFeatureState 函式會要求功能數據表及其子系中功能選取狀態的變更。 接著,所有連結至已變更功能記錄之元件的動作狀態也會根據新功能選取狀態適當地更新。
必須先呼叫 MsiSetInstallLevel 函式,才能呼叫 MsiSetFeatureState。
呼叫 MsiSetFeatureState 時,安裝程式會嘗試將系結至指定功能之每個元件的動作狀態設定為指定的狀態。 不過,當無法完全實作要求時,有一些常見情況。 例如,如果功能系結至兩個元件、元件 A 和元件 B、透過 FeatureComponents 數據表,而元件 A 具有 msidbComponentAttributesLocalOnly 屬性,而元件 B 具有 msidbComponentAttributesSourceOnly 屬性。 在此情況下,如果 MsiSetFeatureState 的呼叫狀態為 INSTALLSTATE_LOCAL 或 INSTALLSTATE_SOURCE,則無法針對這兩個元件完整實作要求。 在此情況下,這兩個元件都會開啟,元件 A 會設定為 [本機],而元件 B 會設定為 [來源]。
如果多個功能連結到單一元件 (常見案例) ,該元件的最終動作狀態會決定如下:
- 如果至少有一個功能需要在本機安裝元件,此功能會安裝為本機狀態。
- 如果至少有一個功能需要從來源執行元件,此功能會以來源的狀態安裝。
- 如果至少有一個功能需要移除元件,則動作狀態不存在。
如果函式失敗,您可以使用 MsiGetLastErrorRecord 取得擴充錯誤資訊。
注意
msiquery.h 標頭會根據 UNICODE 預處理器常數的定義,將 MsiSetFeatureState 定義為別名,自動選取此函式的 ANSI 或 Unicode 版本。 混合使用編碼中性別名與非編碼中性的程序代碼,可能會導致編譯或運行時間錯誤不符。 如需詳細資訊,請參閱 函式原型的慣例。
規格需求
需求 | 值 |
---|---|
最低支援的用戶端 | Windows Server 2012、Windows 8、Windows Server 2008 R2 或 Windows 7 上的 Windows Installer 5.0。 Windows Server 2008 或 Windows Vista 上的 Windows Installer 4.0 或 Windows Installer 4.5。 Windows Server 2003 或 Windows XP 上的 Windows Installer |
目標平台 | Windows |
標頭 | msiquery.h |
程式庫 | Msi.lib |
Dll | Msi.dll |