将数据保存到sqlite本地数据库的速度太慢。任何想法如何让它更快?

时间:2015-12-18 04:19:43

标签: c# sqlite windows-phone-8.1 database-performance

我正在努力将数据更快地保存到本地数据库。

即使这是一次性保存,当应用程序第一次运行时,在Lumia 920中需要90秒才能“仅”保存“地图表”。

我做什么: 1)我调用一个API,在那里我收到所有的网格,包括Xs,Ys,Map Id等。 2)我根据我定义的类反序列化信息。 3)对于每个项目,在该信息中,我保存“misc”信息(因为我将使用它) 4)我在GRIDS表中保存前一项中的每个网格。

此代码snipet是我用来反序列化信息,并调用函数保存在数据库中

public class Maps
{
        public string id { get; set; }
        public string name { get; set; }
        public string height { get; set; }
        public string width { get; set; }
        public string tile { get; set; }
        public string shopping_id { get; set; }
        public string url { get; set; }
        public string updated_at { get; set; }
        public string created_at { get; set; }
        public GridFirst gridFirst { get; set; }
        public GridLast gridLast { get; set; }
        public List<Grid> grid { get; set; }


    public class GridFirst
    {
        public string id { get; set; }
        public string x { get; set; }
        public string y { get; set; }
        public string maps_id { get; set; }
        public string value { get; set; }
    }

    public class GridLast
    {
        public string id { get; set; }
        public string x { get; set; }
        public string y { get; set; }
        public string maps_id { get; set; }
        public string value { get; set; }
    }

    public class Grid
    {
        public string id { get; set; }
        public string x { get; set; }
        public string y { get; set; }
        public string maps_id { get; set; }
        public string value { get; set; }
    }

    public void deserializeAndConvert(string aaa)
    {
        JObject myGeneral = JObject.Parse(aaa);
        IList<JToken> results = myGeneral["resp"].Children().ToList();

        // serialize JSON results into .NET objects
        IList<Maps> searchResults = new List<Maps>();
        foreach (JToken result in results)
        {
            Maps searchResult = JsonConvert.DeserializeObject<Maps>(result.ToString());
            searchResults.Add(searchResult);

        }

            var respuesta = from data in searchResults
                       select new
                       {
                           id = data.id,
                           name = data.name,
                           height = data.height,
                           width = data.width,
                           tile = data.tile,
                           url = data.url,
                           lastX = data.gridLast.x,
                           lastY = data.gridLast.y,
                           grid = data.grid
                       };
            foreach (var a in respuesta)
            {
                Database_Controller.getReadyToSaveData("mapinfo", 8, a.id, a.name, a.height, a.width, a.tile, a.url, a.lastX, a.lastY, "", "", "", "", "", "", "");

                foreach (var data in a.grid)
                {
                    Database_Controller.getReadyToSaveData("mapgrid", 5, data.id, data.x, data.y, data.maps_id, data.value, "", "", "", "", "", "", "", "", "", "");
                }
            }
    }
}

这些是在数据库中保存数据的功能

public static void getReadyToSaveData(string dbName, int numberOfParams, string param1, string param2, string param3, string param4, string param5, string param6, string param7, string param8, string param9, string param10, string param11, string param12, string param13, string param14, string param15)
        {
            List<string> myParams = new List<string>();
            myParams.Add(param1);
            myParams.Add(param2);
            myParams.Add(param3);
            myParams.Add(param4);
            myParams.Add(param5);
            myParams.Add(param6);
            myParams.Add(param7);
            myParams.Add(param8);
            myParams.Add(param9);
            myParams.Add(param10);
            myParams.Add(param11);
            myParams.Add(param12);
            myParams.Add(param13);
            myParams.Add(param14);
            myParams.Add(param15);

            List<string> myParamsToDB = new List<string>();
            for (var i = 0; i < numberOfParams; i++)
            {
                myParamsToDB.Add(myParams[i]);
            }

            insertData(dbName, myParamsToDB);
        }

        public static void insertData(string dbName, List<string> paramsToGo)
        {
            try
            {
                using (var connection = new SQLiteConnection("Unicenter.sqlite"))
                {                    
                    if (dbName == "mapgrid")
                    {
                        using (var statement = connection.Prepare(@"INSERT INTO mapgrid (ID,X,Y,MAPS_ID,VALUE)
                                    VALUES(?, ?,?,?,?);"))
                        {
                            statement.Bind(1, paramsToGo[0]);
                            statement.Bind(2, paramsToGo[1]);
                            statement.Bind(3, paramsToGo[2]);
                            statement.Bind(4, paramsToGo[3]);
                            statement.Bind(5, paramsToGo[4]);
                            // Inserts data.
                            statement.Step();
                            statement.Reset();
                            statement.ClearBindings();
                        }
                    }
                    if (dbName == "mapinfo")
                    {
                        using (var statement = connection.Prepare(@"INSERT INTO mapinfo (ID,NAME,HEIGHT,WIDTH,TILE,URL,LASTX,LASTY)
                                    VALUES(?, ?,?,?,?,?,?,?);"))
                        {
                            statement.Bind(1, paramsToGo[0]);
                            statement.Bind(2, paramsToGo[1]);
                            statement.Bind(3, paramsToGo[2]);
                            statement.Bind(4, paramsToGo[3]);
                            statement.Bind(5, paramsToGo[4]);
                            statement.Bind(6, paramsToGo[5]);
                            statement.Bind(7, paramsToGo[6]);
                            statement.Bind(8, paramsToGo[7]);
                            // Inserts data.
                            statement.Step();
                            statement.Reset();
                            statement.ClearBindings();
                        }
                    }                  
                }

            }
            catch (Exception ex)
            {
                Debug.WriteLine("Exception\n" + ex.ToString());
            }
        }

***编辑:作为一种提醒,如果有些人没有看到标签(并将此问题标记为重复),这是FOR WINDOWS PHONE 8.1,因此,函数,引用和类与平面不同C#

有关如何加快速度的想法? ......我做错了什么?

1 个答案:

答案 0 :(得分:-1)

你可以使用parallel.for循环,如果你有大量数据或者你可以很容易地检查每个循环在VS-2015中执行需要多长时间