sqlserver sqlbulkcopy.batchsize设置多少合适

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sqlserver sqlbulkcopy.batchsize设置多少合适相关的知识,希望对你有一定的参考价值。

参考技术A

C#:用SqlBulkCopy来实现批量插入数据 VB也应会有这个类SqlBulkCopy 

SqlBulkCopy是.net2.0的新特性,平时用的很少,但是其功能却是非常强大,对于批量插入数据性能非常优越

代码

/// <summary>
    /// bulk插入
    /// </summary>
    private void BulkInsert()
    
        SqlConnection sqlcon = new SqlConnection("Data Source=LocalHost;Integrated Security=SSPI;Initial Catalog=xiaotest;");
         DateTime beginTime = DateTime.Now;
       
        DataTable dt = new DataTable();
        dt.Columns.Add("n", typeof(string));
        dt.Columns.Add("name", typeof(string));
        for (int i = 1; i < 1000; i++)
        
            DataRow r = dt.NewRow();
            r["n"] = i;
            r["name"] = "xiao";
            dt.Rows.Add(r);
        
       
        sqlcon.Open();
        using (SqlBulkCopy bulk = new SqlBulkCopy("Data Source=LocalHost;Integrated Security=SSPI;Initial Catalog=xiaotest;"))
        
            bulk.BatchSize = 1000;
            bulk.DestinationTableName = "test2";
            bulk.ColumnMappings.Add("n", "n");
            bulk.ColumnMappings.Add("name", "name");
            bulk.WriteToServer(dt);
        
        
        DateTime endTime = DateTime.Now;
        TimeSpan useTime = endTime - beginTime;
        dt.Dispose();
        time = "使用时间" + useTime.TotalSeconds.ToString() + "秒";
        sqlcon.Close();
        sqlcon.Dispose();
 

sqlserver

sqlserver中自定义函数和存储过程有什么区别?

摘自:http://database.ctocio.com.cn/analysis/465/7709465.shtml
【IT专家网独家】SQL Server用户自定义函数和存储过程有类似的功能,都可以创建捆绑SQL语句,存储在server中供以后使用。这样能够极大地提高工作效率,通过以下的各种做法可以减少编程所需的时间:

重复使用编程代码,减少编程开发时间。
隐藏SQL细节,把SQL繁琐的工作留给数据库开发人员,而程序开发员则集中处理高级编程语言。
维修集中化,可以在一个地方做业务上的逻辑修改,然后让这些修改自动应用到所有相关程序中。
乍看之下,用户自定义函数和存储过程的功能似乎一摸一样。但是,其实这两者之间还有一些虽然细微但是很重要的差异:

存储过程是使用EXEC命令独立调用的,而用户自定义函数是在另一个SQL语句中调用的。
l存储程序是允许用户和程序去使用存储过程,而不是允许其存取表格,这样能够增强程序安全性。与标准的SQL Server相比,存储程序限制用户行动权限方面更为细化。例如,如果你有一个货存表格,每次卖出一个货物收银员都要对表格进行更新一次(从货存中把该货品减去一件)。你可以给收银员设置权限,允许其使用decrement_item存储过程,而不是允许他们有任意修改或村表格的权限。
函数必须始终返回一个值(一个标量值或一个表格)。而存储过程可以返回一个标量值、一个表值或无需返回值。
总而言之,存储程序对SQL Server开发员来说是最有价值的宝物之一,用于数据库中,能够大大的提高工作效率,增强安全性,绝对超值。
参考技术A 存储过程:
存储过程可以使得对数据库的管理、以及显示关于数据库及其用户信息的工作容易得多。存储过程是 SQL 语句和可选控制流语句的预编译集合,以一个名称存储并作为一个单元处理。存储过程存储在数据库内,可由应用程序通过一个调用执行,而且允许用户声明变量、有条件执行以及其它强大的编程功能。
存储过程可包含程序流、逻辑以及对数据库的查询。它们可以接受参数、输出参数、返回单个或多个结果集以及返回值。
可以出于任何使用 SQL 语句的目的来使用存储过程,它具有以下优点:
1、可以在单个存储过程中执行一系列 SQL 语句。
2、可以从自己的存储过程内引用其它存储过程,这可以简化一系列复杂语句。
3、存储过程在创建时即在服务器上进行编译,所以执行起来比单个 SQL 语句快。

用户定义函数:
Microsoft SQL Server 2000 允许创建用户定义函数。与任何函数一样,用户定义函数是可返回值的例程。根据所返回值的类型,每个用户定义函数可分成以下三个类别:
1、返回可更新数据表的函数
如果用户定义函数包含单个 SELECT 语句且该语句可更新,则该函数返回的表格格式结果也可以更新。
2、返回不可更新数据表的函数
如果用户定义函数包含不止一个 SELECT 语句,或包含一个不可更新的 SELECT 语句,则该函数返回的表格格式结果也不可更新。
3、返回标量值的函数
用户定义函数可以返回标量值。

以上是关于sqlserver sqlbulkcopy.batchsize设置多少合适的主要内容,如果未能解决你的问题,请参考以下文章

sqlserver和mysql区别

博客目录SqlServer篇

sqlserver怎么导出数据库

sqlserver最多创建多少分区

怎么导出sqlserver数据库

vs2017中显示检测到不兼容的sqlserver版本