首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >将C#嵌套对象保存到SQL server的有效方法

将C#嵌套对象保存到SQL server的有效方法
EN

Stack Overflow用户
提问于 2014-09-14 23:33:41
回答 2查看 3.5K关注 0票数 5

我有一个表结构,它嵌套到5个层次,一个到多个关系向下。我想知道将这种数据保存到Server中的有效方法是什么。我现在循环每个子对象(C#)并运行一个insert,如果数据很大,插入就会变慢。

在传统的C#中是否有一种直接将ADO.NET传递给ADO.NET的方法?我有一个自定义框架,它为每个insert触发一个SQL脚本,它从对象属性中获取值。我不能转移到EF或NHirbernate,因为这是一个现有的项目。

我已经看到了将C#对象插入到DataTables中然后传递给SQl的方法,这是一种有效的方法吗?

请给我建议。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-09-15 00:10:24

我假设您从数据库的角度来看有这样的东西

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
CREATE TABLE Items (ID INT -- primary key, 
                    Name VARCHAR(MAX),
                    ParentID INT) -- foreign key that loops on the same table

在C#中有一个这样的对象

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public class Item
{
   public int ID {get; set;}
   public string Name {get; set;}
   public int ParentID {get; set;}
   public Item Parent {get; set;}
   public List<Item> Children {get; set;}
}

你有一些代码看起来是:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var root = MakeMeATree();
databaseSaver.SaveToDatabase(root);

为每个子项目生成一个插入项。如果你有很多孩子,这真的可以减缓应用程序的速度。

在这种情况下,我将使用(并且已经使用)一个自定义sql服务器类型和一个存储过程来将整个事件保存在一个调用中。

您需要创建一个与表匹配的类型:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
CREATE TYPE dbo.ItemType AS TABLE
(
    ID INT,
    Name VARCHAR(MAX),
    ParentID INT
);

以及使用以下类型的简单过程:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
CREATE PROCEDURE dbo.InsertItems
(
  @Items AS dbo.ItemType READONLY
)
AS
BEGIN
  INSERT INTO SampleTable(ID, Name, ParentID)
  SELECT ID, Name, ParentID From @Items
END

现在,这是从Server端执行的。现在转到C#侧。你需要做两件事:

  1. 将层次结构扁平化为列表
  2. 将该列表作为datatable发送到数据库

第一种方法可以使用类似于的东西(我使用,这基本上是相同的),只需一个简单的

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var items = root.Flatten(i => i.Children);

要做第二件事,首先需要将Server类型声明为datatable:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
DataTable dt = new DataTable("Items"); 
dt.Columns.Add("ID", typeof(int)); 
dt.Columns.Add("Name", typeof(string)); 
dt.Columns.Add("ParentID", typeof(int)); 

接下来,只需填充以下值:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
foreach(var item in items)
{
   dt.Rows.Add(item.ID, item.Name, item.ParentID);
}

并将它们附加到一个应该是SqlParameter类型的SqlDbType.Structured上,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
using (var cmd = new SqlCommand("InsertItems", connection))
{
    cmd.CommandType = CommandType.StoredProcedure;
    var itemsParam = new SqlParameter("@Items", SqlDbType.Structured);
    itemsParam .Value = dt;

    cmd.Parameters.Add(itemsParam);
    cmd.ExecuteNonQuery();
}

应该是这样的。

票数 6
EN

Stack Overflow用户

发布于 2014-09-15 00:10:09

是的,如果希望将Dataset对象存储在DataBase中,可以使用选项,比如创建一个SQL UserDefinedType对象。在存储过程中填充对象、requierd值和read值,并使用您可以存储在Db中的业务逻辑填充Temp中的对象值。

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25842909

复制
相关文章
C# dotnet 将 Stream 保存到文件的方法
这里的 inputStream.Seek(0, SeekOrigin.Begin); 不一定需要,请根据你自己的需求,如你只需要将这个 Stream 的从第10个byte开始复制等就不能采用这句代码
林德熙
2020/03/20
4.2K0
sql server 将二进制字段保存到磁盘文件
当然,myfll作者:木瓜,瓜哥也写了一套dll,应对用MSSQLSERVER管理文件的DLL, 应瓜哥要求,仅供欣赏。
加菲猫的VFP
2022/02/17
7570
sql server 将二进制字段保存到磁盘文件
sql server嵌套查询实验_exists嵌套查询
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/169426.html原文链接:https://javaforall.cn
全栈程序员站长
2022/09/22
1.8K0
将图片保存到XML文件的方法
一.保存图片到XML文件 /// <summary> /// 保存图片到XML文件 /// </summary> private void UploadImageToXml() { ///得到用户要上传的文件名 string strFilePathName = loFile.PostedFile.FileName; string strFileName = Path.GetFileName(strFilePathName); int FileLength = loFile.Post
跟着阿笨一起玩NET
2018/09/18
2.4K0
C# 的sql server like 的参数
//试了多种方式,这样写like的参数才正确 sb.Append(" and a.GOODSID like '%'+@GOODSID+'%'"); list.Add(new SqlParameter("@GOODSID", Oleno.MODEL.Basis_ware.Ware_code));
乔达摩@嘿
2020/09/11
8350
PHPJSON嵌套对象和数组的解析方法
在PHP编程开发中,JSON是一种非常常用的数据格式。它具有简单、轻量和易于解析的特点,非常适合用于数据交换和存储。当我们处理JSON数据时,经常需要解析嵌套的对象和数组,本文将介绍几种解析方法。
用户10354340
2023/07/26
3210
sql的嵌套查询_sql子查询嵌套优化
最近在做各类小应用,用到了MYSQL,有时候会用到一些比较复杂的嵌套查询,在研究怎么通过SQL实现这些。 假设下面这张表(stu)描述学生的基本信息:
全栈程序员站长
2022/09/22
5.3K0
SQL嵌套查询_sql差集嵌套
派生表就是一个由查询结果生成的临时表。他是在外部查询的 FROM 中定义的。派生表的存在范围只是在外部查询中,只要外部查询结束了,派生表也就不存在了。派生表一定要写在 FROM 后面范围内,用()括起来。后面跟着派生表的名称。
全栈程序员站长
2022/09/22
2.2K0
SQL嵌套查询_sql差集嵌套
sql嵌套查询例子_sql的多表数据嵌套查询
查询学生上课人数超过 “Eastern Heretic” 的任意一门课的学生人数的课程信息,请使用 ANY 操作符实现多行子查询。(Lintcode刷题记录)
全栈程序员站长
2022/09/22
3.1K0
sql中的嵌套查询_sql的多表数据嵌套查询
测试的时候发现取出的是一条数据, 因为测试的时候是一天中的两条数据, 没有不同的日期,所以当日以为是正确的 ,然而第二天写入数据了,要取出数据,却发现没有数据, 返回空的行, 以为都是代码又有问题 了,找了半天都没有 ,仔细看看了存储过程中的代码,发现这样返回的数据的确是空的。
全栈程序员站长
2022/09/22
7.1K0
C#用链式方法表达循环嵌套1
情节故事得有情节,不喜欢情节的朋友可看第1版代码,然后直接跳至“三.想要链式写法” 一.起缘 故事缘于一位朋友的一道题: 朋友四人玩LOL游戏。第一局,分别选择位置:中单,上单,ADC,辅助;第二局新加入的伙伴要选上单,四人可选位置变为:中单,打野,ADC,辅助;要求,第二局四人每人不得选择和第一局相同的位置,请问两局综合考虑有多少种位置选择方式? 对于像我这边不懂游戏的人来讲,看不懂。于是有了这个版本: 有4个人,4只椅子,第一局每人坐一只椅子,第二局去掉第2只椅子,增加第5只椅子,每人坐一只椅子,而且每
逸鹏
2018/04/10
1K0
C#用链式方法表达循环嵌套1
SQL SERVER将查询数据转为INSERT语句
1、在Sql Server数据库中创建存储过程 个人感觉挺有用,Mark一下。 CREATE PROC sp_Data2InsertSQL @TableName AS VARCHAR(100) AS DECLARE xCursor CURSOR FOR SELECT name,xusertype FROM syscolumns WHERE (id = OBJECT_ID(@TableName)) DECLARE @F1 VARCHAR(100) DECLARE @F2 integer DECLA
BrianLee
2022/05/30
1.9K0
SQL SERVER将查询数据转为INSERT语句
SQL Server 2016将支持R编程语言
R编程语言最早出现于1993年,而在2000年,它的第一个符合产品质量的版本R-1.0发布了。自那之后,R就成为了统计分析方面的业界标准,围绕着这门语言出现了大量的图形界面工具,以及可用于各种IDE及文本编辑器的包。 Revolution Analytics是一家成立了9年的公司,他们为R语言提供商业级的支持服务。但就在最近,微软收购了这家公司,作为他们向大数据及机器学习领域迈出的第一步。这次收购的结果是在即将问世的SQL Server 2016中将提供对R语言的支持。 SQL Server R Servi
小莹莹
2018/04/23
1.5K0
SQL Server 2016将支持R编程语言
将Session值储存于SQL Server中
一般情况下,我们喜欢使用Session储存我们的变量。Asp.Net提供了下面一些方法储存Session的值: InProc
Java架构师必看
2021/03/22
8450
C#用链式方法表达循环嵌套2
延迟计算是从Linq借鉴和学习来的,构造Linq的过程并没有执行,等到了执行ToList, First等方法时才真正去执行。 我想构造回调链每一步都是一个固定的方法,这里随便起用了T这个极短名称,而每一步后期计算时要执行的方法可灵活指定。于是有了第3版: static Seat data = new Seat(); //借用Seat保存数据 public Seat2(string name, Seat2 parent, Action<Seat2> method) { this.Name =
逸鹏
2018/04/10
6640
将图片保存到系统相冊的两种方法[通俗易懂]
虽然如此,这样的方法还是仅仅能适合安卓4.4下面的手机,若是4.4以上的手机就会报错。因此建议採用另外一种方式来写。
全栈程序员站长
2022/07/07
6750
sql的嵌套查询_嵌套查询和嵌套结果的区别
SQL连接查询和嵌套查询详解 连接查询 若一个查询同时涉及两个或两个以上的表,则称之为连接查询。连接查询是数据库中最最要的查询,
全栈程序员站长
2022/09/22
4K0
sql的嵌套查询_嵌套查询和嵌套结果的区别
C#将list集合转化为sql
将list集合转化为sql in 的范围对象 比如 List<string> idList= new List<string>(); idList.Add(“001”); idList.Add(“002”); idList.Add(“003”); select * from table where id in (‘001’,‘002’,‘001’) 公共方法 /// <summary> /// C#实现把String字符串转化为SQL语句中的In后接的参数 /// </summary> /// <par
跟着阿笨一起玩NET
2023/02/27
5330
sql中对嵌套查询的处理原则_sql的多表数据嵌套查询
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/169416.html原文链接:https://javaforall.cn
全栈程序员站长
2022/09/22
5.7K0
将数据从 SQL Server 导入 Azure Storage Table
最近有个需求要将数据存储从 SQL Server 数据库切换到 Azure Storage 中的 Table。然而不管是 SSMS 还是 Azure Portal 都没有提供直接的导入功能,是不是又想自己写程序去导数据了?其实不用!没有点过数据库天赋的我996了一个晚上,终于找到了点点鼠标就搞定的方法,今天分享给大家。
Edi Wang
2020/06/15
2K0

相似问题

嵌套sql server更新查询的最有效方法

24

使用c#将图像保存到sql server 2012

10

将嵌套JSON对象映射到DTO对象的有效方法

10

将FlowDocument保存到SQL Server

30

引用嵌套对象的最有效方法

20
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文