1

我有一个名为 searchDB 的方法,它根据用户键入的关键字搜索数据库。

我将搜索结果存储在 DataSet 中。此方法仅搜索一列。

        public DataSet searchDB(string identifier)
        {
            DataSet dataSet = new DataSet();
            OleDbConnection oleConn = new OleDbConnection(connString);

            try
            {
                oleConn.Open();
                string sql = "SELECT [identifier] FROM [Category3] WHERE [identifier] LIKE '" + identifier + "*'";
                //string sql = "SELECT [identifier] FROM [Category3]";

                OleDbDataAdapter dataAdapter = new OleDbDataAdapter(sql, oleConn);
                dataAdapter.Fill(dataSet, "identifier");
            }
            catch (Exception ex)
            {
                Console.WriteLine(ex.ToString());
            }
            finally
            {
                oleConn.Close();
            }
            if (dataSet.Tables[0].Rows.Count == 0)
                {
                    return null;
                }
            else
                return dataSet;
        }

变量“标识符”从textbox. 假设,当我将“windows”作为变量的值传递时,它应该返回 1 行。但是当我放断点时,它正在达到 if 条件

if (dataSet.Tables[0].Rows.Count == 0)
{
    return null;
}

并返回 0 行。

谁能指出我的错误。

4

2 回答 2

0

您似乎使用 SQL LIKE 错误(除非您的identifier列真的以星号结尾):

SELECT [identifier] FROM [Category3] WHERE [identifier] LIKE '" + identifier + "*'

Like 使用%通配符的字符,而不是*,所以尝试:

SELECT [identifier] FROM [Category3] WHERE [identifier] LIKE '" + identifier + "%'

编辑:我没有看到这个问题涉及 MS Access,但答案仍然适用。请参阅以下 SO 问题:为什么 Access 中的 LIKE 查询不返回任何记录?

Access 数据库引擎(Jet、ACE 等)有两种 ANSI 查询模式,每种都使用不同的通配符 > 表示 LIKE:

  • ANSI-89 查询模式使用 *
  • ANSI-92 查询模式使用 %
于 2013-06-13T07:17:43.793 回答
0

LIKE 过滤器应该使用 % 而不是 * 像这里:

 LIKE '" + identifier + "%'
于 2013-06-13T07:18:23.797 回答