Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/sql/74.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/ms-access/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Sql 在语句中使用文本框值_Sql_Ms Access_Textbox - Fatal编程技术网

Sql 在语句中使用文本框值

Sql 在语句中使用文本框值,sql,ms-access,textbox,Sql,Ms Access,Textbox,我在试着让它工作?如何设置要在in()语句中使用的文本框?我希望用户能够列出他们想查询的国家 SELECT * FROM Table WHERE CountryID IN (forms!frmImport!txtCountries) 您不能将文本框的名称直接放入SQL字符串中。 相反,您需要使用文本框的内容构建如下SQL字符串: SELECT * FROM Table WHERE CountryID IN (1,2,3) Dim SQL As String SQL = "SELECT *

我在试着让它工作?如何设置要在
in()
语句中使用的文本框?我希望用户能够列出他们想查询的国家

SELECT *
FROM Table
WHERE CountryID IN (forms!frmImport!txtCountries)

您不能将文本框的名称直接放入SQL字符串中。
相反,您需要使用文本框的内容构建如下SQL字符串:

SELECT * FROM Table WHERE CountryID IN (1,2,3)
Dim SQL As String

SQL = "SELECT * FROM Table WHERE CountryID IN (" & Forms!frmImport!txtCountries & ")"
如果用户在文本框中输入以逗号分隔的CountryID列表,则可以按如下方式构建SQL:

SELECT * FROM Table WHERE CountryID IN (1,2,3)
Dim SQL As String

SQL = "SELECT * FROM Table WHERE CountryID IN (" & Forms!frmImport!txtCountries & ")"
但我不会这样做,因为它很简单,但容易出现输入错误和SQL注入

更好的方法是使用列表框,设置
Multi-Select
属性(以便可以选择多个条目),并用所有可用国家/地区的列表填充它

然后,用户可以选择他想要的,您可以使用列表框中的选定项构建SQL字符串:

Dim ListItem As Variant
Dim CountryList As String
Dim SQL As String

For Each ListItem In Forms!frmImport!lstCountries.ItemsSelected
    If CountryList > "" Then
        CountryList = CountryList & ","
    End If
    CountryList = CountryList & ListItem
Next

SQL = "SELECT * FROM Table WHERE CountryID IN (" & CountryList & ")"

什么技术?ASp.NET?Php?Html?电话应用程序?使用SQL或VBA访问中的Oops