共用方式為


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 函式會要求變更功能 功能 數據表及其子系中的功能選取狀態。 接著,所有連結至已變更功能記錄之元件的動作狀態也會根據新功能選取狀態適當地更新。

呼叫 msiSetFeatureState 之前,必須先呼叫 MsiSetInstallLevel 函式。

呼叫 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
目標平臺 窗戶
標頭 msiquery.h
連結庫 Msi.lib
DLL Msi.dll

另請參閱

安裝程式選取函式