共用方式為


msiSetFeatureStateA 函式 (msiquery.h)

MsiSetFeatureState 函式會將功能設定為指定的狀態。

語法

UINT MsiSetFeatureStateA(
  [in] MSIHANDLE    hInstall,
  [in] LPCSTR       szFeature,
  [in] INSTALLSTATE iState
);

參數

[in] hInstall

處理提供給 DLL 自定義動作的安裝,或透過 MsiOpenPackageMsiOpenPackageExMsiOpenProduct 取得。

[in] szFeature

指定功能的名稱。

[in] iState

指定要設定的狀態。 此參數可以是下列其中一個值。

意義
INSTALLSTATE_ABSENT
未安裝此功能。
INSTALLSTATE_LOCAL
此功能安裝在本機磁碟驅動器上。
INSTALLSTATE_SOURCE
此功能是從來源、CD 或網路執行。
INSTALLSTATE_ADVERTISED
此功能已公告。

傳回值

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

另請參閱

安裝程式選取函式