将list<对象>转换成DataTable,把DataTable转换成参数传入存储过程实现批量插入数据

时间:2022-05-04 08:55:06

领导让在存储过程中批量添加数据,找出效率最高的,我看到后台代码后,发现可以将list<对象>转换成DataTable,把DataTable转换成参数传入存储过程实现批量插入数据,知道还有其他的方法,不过这个方法已经实现,就写一下了:

  1.创建表。

CREATE TABLE [dbo].[person](
[ID] [int] IDENTITY(,) NOT NULL,
[Name] [nvarchar]() NULL,
[Pwd] [nvarchar]() NULL,
[Age] [int] NULL

  2.创建表值参数类型

我们打开查询分析器,然后在查询分析器中执行下列代码:

create type pson as table
(
[Name] [nvarchar]() NULL,
[Pwd] [nvarchar]() NULL,
[Age] [int] NULL
)
go

  执行成功以后,我们打开企业管理器,按顺序依次展开下列节点--数据库、展开可编程性、类型、用户自定义表类型,就可以看到我们创建好的表值类型了如下图所示:

  将list<对象>转换成DataTable,把DataTable转换成参数传入存储过程实现批量插入数据 

说明我们创建表值类型成功了。

  3.编写存储过程

存储过程的代码为:

  create proc sp_InsertSingleUser
(
    @User pson readonly
)
as
BEGIN

SET NOCOUNT ON;

Insert into person(Name,Pwd,Age) select Name,Pwd,Age from @User

END

4.编写代码调用存储过程。

  添加数据按钮的功能

 List<person> pList = new List<person>();             //声明集合
person p1 = new person(); //个人实体对象
p1.Name = "a";
p1.Pwd = "";
p1.Age =;
pList.Add(p1); person p2 = new person(); //个人实体对象
p2.Name = "b";
p2.Pwd = "";
p2.Age =;
pList.Add(p2); XmlSerializer s = new XmlSerializer(typeof(List<person>));
StringWriter sw = new StringWriter();
s.Serialize(sw,pList);
DataSet ds = new DataSet();
ds.ReadXml(new StringReader(sw.ToString()));
DataTable dt = ds.Tables[]; TVPInsert(dt);

  Dal层的编码

  private static void TVPInsert(DataTable dt)
{ DataTable dataTable = dt;
try
{
SqlParameter[] sqlParameter = { new SqlParameter("@User", dataTable) };
SqlHelper.ExecuteNonQuery(strCon, CommandType.StoredProcedure, "sp_InsertSingleUser", sqlParameter);
}
catch (Exception)
{ throw;
} }

将list<对象>转换成DataTable,把DataTable转换成参数传入存储过程实现批量插入数据

这样可实现在存储过程中批量插入数据。

 

将list<对象>转换成DataTable,把DataTable转换成参数传入存储过程实现批量插入数据的更多相关文章

  1. 批量插入数据&comma; 将DataTable里的数据批量写入数据库的方法

    大量数据导入操作, 也就是直接将DataTable里的内容写入到数据库 通用方法: 拼接Insert语句, 好土鳖 1. MS Sql Server:   使用SqlBulkCopy 2. MySql ...

  2. 【C&num;-批量插入数据到数据库】DataTable数据批量插入数据的库三种方法:SqlCommand&period;EcecuteNonQurery&lpar;&rpar;,SqlDataAdapter&period;Update&lpar;DataTable&rpar; ,SqlBulkCopy&period;WriteToServer&lpar;Datatable&rpar;

    第一种方法:使用SqlCommand.EcecuteNonQurery()  效率最慢 第二种方法:使用SqlDataAdapter.Update(DataTable)   效率次之 第三种方法:使用 ...

  3. SQL Server将DataTable传入存储过程(Table Value Parameter)

    博主在做毕业设计的时候,需要用到事务处理和多次将数据写入不同的表中,但是 SQL Server 数据库是不支持数组类型变量的,想要实现数组的功能,可以通过 XML 和数据表的方法实现,但是实现方法非常 ...

  4. &period;net使用SqlBulkCopy类操作DataTable批量插入数据库数据,然后分页查询坑

    在使用SqlBulkCopy类操作DataTable批量插入数据,这种操作插入数据的效率很高,就会导致每一条数据在保存的时间基本一样,在我们分页查询添加的数据是,使用数据的添加时间来排序就会出现每页的 ...

  5. 对象列表转换为DataTable或DataTable转换为对象列表&period;

    /**********************************************************************************/ // 说明: 数据转换工具. ...

  6. Table转换成实体、Table转换成实体集合&lpar;可转换成对象和值类型&rpar;

    /// <summary> /// Table转换成实体 /// </summary> /// <typeparam name="T">< ...

  7. 生成二维码 加密解密类 TABLE转换成实体、TABLE转换成实体集合&lpar;可转换成对象和值类型&rpar; COOKIE帮助类 数据类型转换 截取字符串 根据IP获取地点 生成随机字符 UNIX时间转换为DATETIME&bsol;DATETIME转换为UNIXTIME 是否包含中文 生成秘钥方式之一 计算某一年 某一周 的起始时间和结束时间

    生成二维码 /// <summary>/// 生成二维码/// </summary>public static class QRcodeUtils{private static ...

  8. C&num; DataTable和List转换操作类

    using System; using System.Collections.Generic; using System.Data; using System.Linq; using System.R ...

  9. 关于datatable linq的转换

    关于datatable datarow DataTable paraval = GetParaVal(DateCondition, strUrl, Page, RowPage, iYearMonthN ...

随机推荐

  1. Java ConcurrentHashMap Example and Iterator--转

    原文地址:http://www.journaldev.com/122/java-concurrenthashmap-example-iterator#comment-27448 Today we wi ...

  2. LINUX 下Open cv练习使用小记(2)

    第二节记录一下自己学习图像遍历的一点点代码,摘自<opencv2编程手册>(张静译) 第一个代码是最简单的强行修改像素(添加椒盐噪声) #include <opencv2/core/ ...

  3. SQL中获取最近的N个半年度

    直接上代码: --获取往前推的N个半年度 CREATE FUNCTION F3_GetRecentNHalfYear ( @N INT ) RETURNS @Result TABLE ( Year S ...

  4. django-cms 代码研究(三)插件&lpar;plugs in&rpar;

    插件(plugs in) djangocms支持的插件有: http://docs.django-cms.org/en/latest/basic_reference/plugin_reference. ...

  5. 【POJ3358】

    题目描述: 题意: 就是给定一个a/b,求a/b的结果变成二进制之后的小数.这个小数后面会有一段循环节,只要求输出循环节开始循环的位置和循环长度. 分析: 这题我是这么想的,比如说样例中的1/5,我们 ...

  6. 【BZOJ 2143】 飞飞侠

    Description 飞飞国是一个传说中的国度,国家的居民叫做飞飞侠.飞飞国是一个N×M的矩形方阵,每个格子代表一个街区.然而飞飞国是没有交通工具的.飞飞侠完全靠地面的弹射装置来移动.每个街区都装有 ...

  7. Mesh Baker的基本操作与功能演示

    原地址:http://www.narkii.com/club/thread-301789-1.html 如何降低游戏在系统中的消耗并带给用户最佳的体验是开发者一直追求的目标,在Unity里面对于模型与 ...

  8. JAVA打印类(带预览)

    package tool; import java.awt.*; import java.awt.event.KeyEvent; import java.awt.event.KeyListener; ...

  9. PHP中&colon;&colon;的使用

    访问静态变量,静态属性,const修饰的变量.

  10. java:构造方法:无参构造&sol;有参构造 this static关键字 静态变量 静态方法 代码块 封装 静态常量。

    /*构造方法是一种特殊的方法,专门用于构造/实例化对象,形式:[修饰符] 类名(){ }构造方法根据是否有参数分为无参构造和有参构造*/public class Dog {               ...