生成数字并插入db的更有效,最快捷的方法

时间:2011-09-01 08:14:27

标签: asp.net-mvc entity-framework c#-4.0 entity-framework-4

大家好我拥有以下代码,用于生成电话号码并将其插入数据库中的表格中。为了生成代码,它在数据库的表中查找,以查看哪个“F”数字数字需要为一个范围生成。因此,例如利兹范围“01132 21”,需要生成1,3,4和6的数字。因此生成的数字将类似于01132211000-01132211999,01132213000-01132213999等。

这正如我所希望的那样正常工作。然而,这需要相当长的时间(需要12个小时来生成120,000条记录,我估计我们可能会产生大约一百万条记录。只是想知道是否有更快捷的方式来做我想要的。我还是一个非常“绿色的“开发者,所以不知道最好的做事方式!”

private TelephoneNumberManagementEntities context = new TelephoneNumberManagementEntities();

public ActionResult Index()
{
    var list = context.TempNumberImports.ToList();
    foreach (var item in list)
    {
        string range = item.Range.ToString().Trim().Replace(" ","");

        if (item.C0 == "Y")
        {
            GenerateNumbers(range, 0, 999, item.ID);
        }
        if (item.C1 == "Y")
        {
            GenerateNumbers(range, 1000, 1999, item.ID);
        }
        if (item.C2 == "Y")
        {
            GenerateNumbers(range, 2000, 2999, item.ID);
        }
        if (item.C3 == "Y")
        {
            GenerateNumbers(range, 3000, 3999, item.ID);
        }
        if (item.C4 == "Y")
        {
            GenerateNumbers(range, 4000, 4999, item.ID);
        }
        if (item.C5 == "Y")
        {
            GenerateNumbers(range, 5000, 5999, item.ID);
        }
        if (item.C6 == "Y")
        {
            GenerateNumbers(range, 6000, 6999, item.ID);
        }
        if (item.C7 == "Y")
        {
            GenerateNumbers(range, 7000, 7999, item.ID);
        }
        if (item.C8 == "Y")
        {
            GenerateNumbers(range, 8000, 8999, item.ID);
        }
        if (item.C9 == "Y")
        {
            GenerateNumbers(range, 9000, 9999, item.ID);
        }
    }
    return View();
}

public void GenerateNumbers(string range, int startNo, int endNo, int rangeID)
{
    Number num = new Number();
    for (int i = startNo; i <= endNo; i++)
    {
        if (startNo == 0)
        {
            string tempNum = range + i.ToString("D4");
            var record = context.Numbers.FirstOrDefault(m => m.Number1 == tempNum);
            if (record == null)
            {
                num.Number1 = tempNum;
                num.RangeID = rangeID;
                num.StatusID = 1;
                num.ImportDate = DateTime.Now;
                num.ImportSource = "Number Ranges 250811.xlsx";
                context.Numbers.Add(num);
                context.SaveChanges();
            }
        }
        else
        {
            string tempNum = range + i;
            var record = context.Numbers.FirstOrDefault(m => m.Number1 == tempNum);
            if (record == null)
            {
                num.Number1 = tempNum;
                num.RangeID = rangeID;
                num.StatusID = 1;
                num.ImportDate = DateTime.Now;
                num.ImportSource = "Number Ranges 250811.xlsx";
                context.Numbers.Add(num);
                context.SaveChanges();
            }
        }
    }
}

1 个答案:

答案 0 :(得分:1)

简单回答:使用存储过程

您当前的解决方案将产生数千个数据库往返,因为每个数字都将插入到单独的数据库调用中。

您还可以考虑批量准备数据并使用SqlBulkCopy