[英]MS-Access How to use iif in query criteria
我有一個包含文本框的搜索表單,我想根據大於在文本框中輸入的值過濾字段,但在文本框為空時返回所有字段。 為此,我在查詢條件中編寫了以下代碼,但出現錯誤
IIf(IsNull(TextBox); TheField; >TextBox))
當在 MS Access 的查詢生成器中指定為特定字段的條件時,您輸入的表達式可能會被解釋為以下where
子句:
where TheField = IIf(IsNull(TextBox), TheField, TheField > TextBox))
如果TheField
不包含 boolean 值,則可能會產生數據類型不匹配錯誤,因為else分支將產生where
子句:
where TheField = (TheField > TextBox)
這將是以下之一:
where TheField = True
where TheField = False
相反,我建議將以下內容指定為您的 SQL where
子句:
where Forms!YourFormName!YourTextBox is null or TheField > Forms!YourFormName!YourTextBox
我會推薦:
where (textbox is null or thefield > textbox)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.