每次迭代SQL查询都会变慢?

时间:2011-07-23 03:27:44

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

还有什么方法可以让这个SQL查询更快?它在.sdf数据库中搜索匹配的单词。数据按字母顺序排列。目前搜索需要大约10-15秒,搜索的第一次迭代似乎相当快,但每次迭代搜索变得更慢?为什么是这样?对不起,这是我第一次使用SQL。

private void Search_Database() //Searches SQL Database for matching words
{
    Possible_Words.Clear();
    using (var cn = new SqlCeConnection(@"Data Source=|DataDirectory|\Resource\Wordlist.sdf"))
    {
        cn.Open();
        using (var cmd = cn.CreateCommand())
        {
            string[] Final_Search_Array = (string[])Packaged_Search_Array.ToArray(typeof(string)); // Receives  and Unwraps Packaged Array
            int Search_Array_Index = Final_Search_Array.Length - 1;
            for (; Search_Array_Index != -1; Search_Array_Index = Search_Array_Index - 1)
            {
                switch (Final_Search_Array[Search_Array_Index].Length)
                {
                    case 2:
                        Search_Table = "[2 Letter Words]";
                        break;
                    case 3:
                        Search_Table = "[3 Letter Words]";
                        break;
                    case 4:
                        Search_Table = "[4 Letter Words]";
                        break;
                    case 5:
                        Search_Table = "[5 Letter Words]";
                        break;
                    case 6:
                        Search_Table = "[6 Letter Words]";
                        break;
                }
                cmd.CommandText = "Select * from " + Search_Table + " where [Melted] like '%" + Final_Search_Array[Search_Array_Index] + "%'";
                using (var reader = cmd.ExecuteReader())
                {
                    while (reader.Read())
                    {
                        Possible_Words.Add(reader["Word"].ToString());
                    }
                }
            }
        }
        cn.Close();
    }
    FullList_PossibleWords.Add(Possible_Words);
}

1 个答案:

答案 0 :(得分:3)

一些提示:

  1. 不要在查询中使用*,而是使用所有字段名称。

  2. Melted 字段上创建索引。

  3. 在创建Connection对象和Command

  4. 之外构建查询
  5. 在需要时打开连接,而不是在代码的开头

  6. 如果您考虑这些提示,您的代码会变得更快。