zoukankan      html  css  js  c++  java
  • Linq to sql中如何使用一个统一事务保存级联表格

    需要使用到DataContext的嵌套

     

    服务代码如下:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Data.Linq;
    using System.Configuration;

    namespace CsharpTrainer.Linq.Service.Northwind
    {
        public class CascadeTableService
        {
            public bool AddCascadeTables(CascadeA tableA, List<CascadeB> tablesB, List<CascadeC> tablesC)
            {
                bool result;
                
                try
                {
                    using (DataContext context = new DataContext(ConfigurationManager.ConnectionStrings["NorthwindConnStr"].ToString()))
                    {
                        using (NorthwindDBDataContext northwindContext = new NorthwindDBDataContext())
                        {
                            northwindContext.CascadeA.InsertOnSubmit(tableA);
                            northwindContext.CascadeB.InsertAllOnSubmit(tablesB);
                            northwindContext.CascadeC.InsertAllOnSubmit(tablesC);

                            northwindContext.SubmitChanges();
                        }

                    }

                    result = true;
                }
                catch (Exception ex)
                {
                    Console.WriteLine(ex.Message);

                    result = false;
                }

                return result;
            }
        }
    }

    客户端测试代码如下:

    Guid caId, cbId, ccId;
                
                caId = Guid.NewGuid();
                CascadeA tableA = new CascadeA
                {
                    CaId = caId,
                    CaContent = "Content A1"
                };
                
                List<CascadeB> tablesB = new List<CascadeB>();
                List<CascadeC> tablesC = new List<CascadeC>();
                CascadeB tableB;
                CascadeC tableC;
                for (int i = 1; i <= 3; i++)
                {
                    cbId = Guid.NewGuid();
                    tableB = new CascadeB
                    {
                        CbId = cbId,
                        CaId = caId,
                        CbContent = "Content B" + i.ToString()
                    };
                    tablesB.Add(tableB);

                    for (int j = 1; j <= 3; j++)
                    {
                        ccId = Guid.NewGuid();
                        tableC = new CascadeC
                        {
                            CcId = ccId,
                            CbId = cbId,
                            CcContent = "Content C" + i.ToString() + j.ToString()
                            //CcContent = sb.ToString()
                        };
                        tablesC.Add(tableC);
                    }
                }

                CascadeTableService service = new CascadeTableService();
                bool result = service.AddCascadeTables(tableA, tablesB, tablesC);
                if (result)
                    Console.WriteLine("Add Cascade Tables Successfully!");
                else
                    Console.WriteLine("Failed to add cascade tables!");
    技术改变世界
  • 相关阅读:
    Atitit 华为基本法 attilax读后感
    Atitit 华为管理者内训书系 以奋斗者为本 华为公司人力资源管理纲要 attilax读后感
    Atitit 项目版本管理gitflow 与 Forking的对比与使用
    Atitit 管理的模式扁平化管理 金字塔 直线型管理 垂直管理 水平管理 矩阵式管理 网状式样管理 多头管理 双头管理
    Atitit 乌合之众读后感attilax总结 与读后感结构规范总结
    深入理解 JavaScript 异步系列(4)—— Generator
    深入理解 JavaScript 异步系列(3)—— ES6 中的 Promise
    深入理解 JavaScript 异步系列(2)—— jquery的解决方案
    深入理解 JavaScript 异步系列(1)——基础
    使用 github + jekyll 搭建个人博客
  • 原文地址:https://www.cnblogs.com/davidgu/p/2411767.html
Copyright © 2011-2022 走看看