如何使用C#在Windows窗体应用程序中搜索SQL Server Compact数据库?

时间:2015-11-10 06:33:41

标签: c# sql sql-server sql-server-ce

我的搜索代码数据 SQL Server Compact数据库中无效,请查看我的代码。任何帮助将不胜感激。

    #region btnSearch_Click
    private void btnSearch_Click(object sender, EventArgs e)
    {
        SqlCeConnection con = new SqlCeConnection("Data Source="
            + System.IO.Path.Combine(Path.GetDirectoryName(System.Reflection.Assembly.GetEntryAssembly().Location), "Database.sdf"));
        sda = new SqlCeDataAdapter();
        if (con.State == ConnectionState.Closed)
        {
            con.Open();
        }
    string sql = "select Name from tblCustomers ";
    if (tbSearch.Text.Length > 0)
    {
    sql += "where Name like " + tbSearch.Text + " % ";
    }

    try
    {
    SqlCeCommand cmd = new SqlCeCommand(sql, con);
    cmd.CommandType = CommandType.Text;

    // if you don’t set the result set to
    // scrollable HasRows does not work
    SqlCeResultSet rs = cmd.ExecuteResultSet(
    ResultSetOptions.Scrollable);

    if (rs.HasRows)
    {

    int Name = rs.GetOrdinal("Name");


    // Hold the output
    StringBuilder output = new StringBuilder();

    // Read the first record and get it’s data
    rs.ReadFirst();
    output.AppendLine(rs.GetString(Name)
    + " " + rs.GetString(Name));

    while (rs.Read())
    {
    output.AppendLine(rs.GetString(Name)
    + " " + rs.GetString(Name));
    }

    // Set the output in the label
    lblResults.Text = output.ToString();
    }
    else
    {
    lblResults.Text = "No Rows Found.";
    }

    }
    catch (SqlCeException sqlexception)
    {
    MessageBox.Show(sqlexception.Message, "Error.",
    MessageBoxButtons.OK, MessageBoxIcon.Error);
    }
    catch (Exception ex)
    {
    MessageBox.Show(ex.Message, "Error.",
    MessageBoxButtons.OK, MessageBoxIcon.Error);
    }
    finally
    {
    con.Close();
    }

#endregion

它抛出了轰鸣声例外。

  

解析查询时出错。 [令牌行号= 1,令牌行偏移= 53,令牌错误=%]

1 个答案:

答案 0 :(得分:2)

解决此类问题的一种有用方法是在将代码发送到SQL Server之前查看代码生成的SQL字符串。如果你能立即发现问题,那很好 - 修复它。如果您无法直接使用SQL Server Management Studio运行完整查询,并查看是否了解该问题。如果您仍然无法在Q& A网站上将此查询发布为问题(就像在此处一样),那么帮助您会更容易。

在这种情况下,我认为你在{({1}})周围缺少单引号 - 但我无法确定它是否取决于{{1的值}}