EF架构~简洁关联表插入,优越的代码性能!

简介:

entity frameworks给我们代来的不只是操作方便,代码简洁,代码人性化强,而且更重要的是它的代码执行效率也是可以信任的,这一点对于我们来说十分重要,因为对于ORM来说,你再使用方便,再容易上手,如果你的性能低下,我估计也没人爱用,呵呵。

今天主要说一下entity frameworks中的关联表插入问题,我们以订单业务为例来说一下:

一 数据结果图如下:

二 在EF中,数据结构关联图会体现在模型里,并且同时会生成在实体中,它以导航属性的形式出现,如图:

   public partial class Order_Info
    {
        public Order_Info()
        {
            this.Order_Detail = new HashSet<Order_Detail>();
        }
    
        public int OrderID { get; set; }
        public int UserID { get; set; }
        public System.DateTime CreateDate { get; set; }
    
        public virtual ICollection<Order_Detail> Order_Detail { get; set; }
    }

三 使用我们封装好的Add方法,将order_info实体插入,如果order_info里的Order_Detail属性的Count大于0,将会建立Order_info对象的add方法,这一切

由EF内部自动实现,看代码:

       public void Add(T item)
        {
            this.Add(item, true);
        }

        public void Add(T item, bool isSubmit)
        {
            _db.Entry<T>(item);
            _db.Set<T>().Add(item);
            if (isSubmit)
                this.SaveChanges();
        }

四 为order_info 和order_detail赋值,如果它们已经存在了表关联,那么在order_detail里,你不需要为orderid赋值,因为它在.net环境中,还没有确定值

(order_info与order_detail主键都是自增的)。

       public void InsertOrder(Domain.Entities.Order_Info entity)
        {
            using (TransactionScope trans = new TransactionScope())
            {
                try
                {
                    base.Add(entity);
                    trans.Complete();
                }
                catch (Exception)
                {

                    throw;
                }
            }
        }
           Order_Info entity = new Order_Info
            {
                CreateDate = DateTime.Now,
                UserID = 1,
                Order_Detail = new List<Order_Detail>
                {
                    new Order_Detail
                    {
                      ProductID=1,
                      ProductName="香蕉1"
                    },
                     new Order_Detail
                    {
                      ProductID=2,
                      ProductName="香蕉2"
                    }
                }
            };
            new OrderRepository().InsertOrder(entity);

而如果你不建立表关系,你必须自己去做数据插入及orderid赋值的工作,而且更重要的是它生成的SQL代码的性能是低下的,所以,使用EF ORM需要为数据表

做关系,不要愉这个懒,因为这个关系做的值!

四 这个方法所产生的SQL语句是我们可以接受的,通过sql profiler进行代码监控,代码生成如图:

总结:EF为我们生成的SQL语句只建立了一次SQL连接,将insert语句批量发给sqlserver,而这种方式我们是可以接受的,很多ORM工具对于这种情况,将生

成多次connection连接,性能不言而喻,所以,EF在代码执行效率上是可以信任的,呵呵。

本文转自博客园张占岭(仓储大叔)的博客,原文链接:EF架构~简洁关联表插入,优越的代码性能!,如需转载请自行联系原博主。

目录
相关文章
|
3月前
|
存储 调度 C++
16 倍性能提升,成本降低 98%! 解读 SLS 向量索引架构升级改造
大规模数据如何进行语义检索? 当前 SLS 已经支持一站式的语义检索功能,能够用于 RAG、Memory、语义聚类、多模态数据等各种场景的应用。本文分享了 SLS 在语义检索功能上,对模型推理和部署、构建流水线等流程的优化,最终带给用户更高性能和更低成本的针对大规模数据的语义索引功能。
371 26
|
4月前
|
SQL 前端开发 关系型数据库
如何开发一套研发项目管理系统?(附架构图+流程图+代码参考)
研发项目管理系统助力企业实现需求、缺陷与变更的全流程管理,支持看板可视化、数据化决策与成本优化。系统以MVP模式快速上线,核心功能包括需求看板、缺陷闭环、自动日报及关键指标分析,助力中小企业提升交付效率与协作质量。
|
3月前
|
前端开发 JavaScript BI
如何开发车辆管理系统中的车务管理板块(附架构图+流程图+代码参考)
本文介绍了中小企业如何通过车务管理模块提升车辆管理效率。许多企业在管理车辆时仍依赖人工流程,导致违章处理延误、年检过期、维修费用虚高等问题频发。将这些流程数字化,可显著降低合规风险、提升维修追溯性、优化调度与资产利用率。文章详细介绍了车务管理模块的功能清单、数据模型、系统架构、API与前端设计、开发技巧与落地建议,以及实现效果与验收标准。同时提供了数据库建表SQL、后端Node.js/TypeScript代码示例与前端React表单设计参考,帮助企业快速搭建并上线系统,实现合规与成本控制的双重优化。
|
4月前
|
机器学习/深度学习 人工智能 搜索推荐
从零构建短视频推荐系统:双塔算法架构解析与代码实现
短视频推荐看似“读心”,实则依赖双塔推荐系统:用户塔与物品塔分别将行为与内容编码为向量,通过相似度匹配实现精准推送。本文解析其架构原理、技术实现与工程挑战,揭秘抖音等平台如何用AI抓住你的注意力。
986 7
从零构建短视频推荐系统:双塔算法架构解析与代码实现
|
4月前
|
监控 供应链 前端开发
如何开发ERP(离散制造-MTO)系统中的财务管理板块(附架构图+流程图+代码参考)
本文详解离散制造MTO企业ERP系统中财务管理模块的搭建,聚焦应收账款与应付账款管理,涵盖核心功能、业务流程、开发技巧及Python代码示例,助力企业实现财务数据准确、实时可控,提升现金流管理能力。
|
4月前
|
供应链 监控 JavaScript
如何开发ERP(离散制造-MTO)系统中的库存管理板块(附架构图+流程图+代码参考)
本文详解MTO模式下ERP库存管理的关键作用,涵盖核心模块、业务流程、开发技巧与代码示例,助力制造企业提升库存周转率、降低缺货风险,实现高效精准的库存管控。
|
4月前
|
前端开发 API 定位技术
如何开发车辆管理系统中的用车申请板块(附架构图+流程图+代码参考)
本文详细解析了如何将传统纸质车辆管理流程数字化,涵盖业务规则、审批流、调度决策及数据留痕等核心环节。内容包括用车申请模块的价值定位、系统架构设计、数据模型构建、前端表单实现及后端开发技巧,助力企业打造可落地、易扩展的车辆管理系统。
|
4月前
|
设计模式 人工智能 API
AI智能体开发实战:17种核心架构模式详解与Python代码实现
本文系统解析17种智能体架构设计模式,涵盖多智能体协作、思维树、反思优化与工具调用等核心范式,结合LangChain与LangGraph实现代码工作流,并通过真实案例验证效果,助力构建高效AI系统。
548 7
|
3月前
|
Cloud Native Serverless API
微服务架构实战指南:从单体应用到云原生的蜕变之路
🌟蒋星熠Jaxonic,代码为舟的星际旅人。深耕微服务架构,擅以DDD拆分服务、构建高可用通信与治理体系。分享从单体到云原生的实战经验,探索技术演进的无限可能。
微服务架构实战指南:从单体应用到云原生的蜕变之路