我的ORM之六-- 批量
很多时候,批量方案是解决性能的关键
批量插入
SqlBulkCopy
利用 SqlBulkCopy 是性能最高的方式
实现:
var s = dbr.Menu.NewMyOqlSet();
s.AddRow(o => o.Id == & o.Name == "");
s.AddRow(o => o.Id == & o.Name == "");
s.BulkCopy2Db();
Insert2Db 方法:(内部调用BeginBatchInsert 方法)
var set = dbr.Menu.NewMyOqlSet();
set.Columns = new Columns(dbr.Menu.Name).ToArray();
set.AddRow(o => o.Name == "");
set.AddRow(o => o.Name == "");
set.Insert2Db();
BeginBatchInsert:
var set = dbr.Menu.BeginBatchInsert(dbr.Menu.Name);
set.Insert(o => o.Name == "");
set.Insert(o => o.Name == "");
set.Execute();
生成如下SQL:
insert into [S_Menu]
([Name])
output inserted.[ID]
values
(''),('');
批量更新
Update2Db:(内部调用 BeginBatchUpdate)
var s = dbr.Menu.NewMyOqlSet();
s.AddRow(o => o.Id == 1 & o.Name == "33");
s.AddRow(o => o.Id == 2 & o.Name == "444");
s.Update2Db(o => o.CorpID == 1, o => new SimpleColumn[] { o.Id }, o => new SimpleColumn[] { o.Name });
Update2Db方法中的
第一个参数是 Where 的条件,表示一个基本的数据约束,用于防止数据污染。可以为 null
第二个参数表示关联的唯一列
第三个参数是 更新时设置的列。
BeginBatchUpdate方法
var beg = dbr.Menu.BeginBatchUpdate(o=>o.CorpID == 1 ,o=>o.Id);
beg.Update(o => o.Name == "" & o.Id == );
beg.Update(o => o.Name == "" & o.Id == );
beg.Execute();
生成的SQL:(MySql)
CREATE TEMPORARY TABLE `Temp_MyOql_16`(
`PID` int,`Css` varchar(50),
`Url` varchar(250),
`Wbs` varchar(50),
`IsLeaf` bit,
`Name` nvarchar(50),
`SortID` real,
`Group` nvarchar(50),
`IsValidate` bit,
`ID` int)
ENGINE=MEMORY DEFAULT CHARSET=utf8; insert into `Temp_MyOql_16`(`PID`,`Css`,`Url`,`Wbs`,`IsLeaf`,`Name`,`SortID`,`Group`,`IsValidate`,`ID`) values
(null,null,null,null,null,'',null,null,null,1),
(null,null,null,null,null,'',null,null,null,2); UPDATE `S_Menu` AS t,
`Temp_MyOql_16` AS o
SET
t.`PID` = o.`PID`,
t.`Css` = o.`Css`,
t.`Url` = o.`Url`,
t.`Wbs` = o.`Wbs`,
t.`IsLeaf` = o.`IsLeaf`,
t.`Name` = o.`Name`,
t.`SortID` = o.`SortID`,
t.`Group` = o.`Group`,
t.`IsValidate` = o.`IsValidate`
WHERE
t.`CorpID` = 1 and t.`ID` = o.`ID`; drop table `Temp_MyOql_16`;
批量推送
批量推送,是结合批量更新和批量,当有一个数据集,需要更新或添加到数据库中时使用。有则更新,无则添加。
var insertType = dbr.PlatForm.CarType.NewMyOqlSet();
//insertType.添加数据
insertType.Save2Db(o => null, o => o.OtherID, true);
Save2Db方法中的
第一个参数:是更新的条件 。
第二个参数是 更新时,关联的唯一列。
第三个参数表示是否要保留 更新条件结果集 - MyOqlSet结果集。 如: 参数为false , 更新条件是 Id < 100 , MyOqlSet 结果集的Id 是 1-50 ,则删除数据库中 Id 从50到100 的记录。
我的ORM之六-- 批量的更多相关文章
- Django orm 实现批量插入数据
Django ORM 中的批量操作 在Hibenate中,通过批量提交SQL操作,部分地实现了数据库的批量操作.但在Django的ORM中的批量操作却要完美得多,真是一个惊喜. 数据模型定义 首先,定 ...
- 我的ORM汇总
MyOql是我写的ORM,目前仅支持 MSSql2005+ ,从2009年到今天,已使用过不少项目,之后会写 其它关系数据库的解析器: MySql,Sqlite,Oracle 等. 代码地址(最新版) ...
- 我的ORM之二--添加
我的ORM索引 添加的语法: var 影响行数 = dbr.表.Insert(实体).Execute(); 实体类型 1. 任何C#类. 如:public class Entity{ public ...
- 我的ORM之三 -- 更新
我的ORM索引 更新语法 var 影响行数 = dbr.表.Update(实体).Where(条件).Execute(); 实体类型: 更新的实体类型和添加的实体类型一样,有三类: 1. 任何C#类. ...
- Django开发之ORM批量操作
版本 1 Python 3.8.2 2 Django 3.0.6 批量入库 场景: 前端页面通过 textarea 文本框提交一列多行数据到Django后台,后台通过ORM做入库操作 表名: Tabl ...
- 极验(Geetest) Laravel 5 集成开发包,让验证更安全
简述 在网站开发中使用频率最高的工具之一便是验证码,验证码在此也是多种多样,不过简单的图片验证码已经可以被机器识别,极验验证码提供了一个安全可靠的滑动验证码体系,让网站开发更加安全. 先感受一下这种验 ...
- Odoo12 重大改变
Table of Contents 重构的功能 ORM 数据导入 库存 库存规则 MRP 多步路线 新功能 IoT Odoo12 预计 2018/10 在 Odoo experience 20 ...
- FluentData-新型轻量级ORM 利用T4模板 批量生成多文件 实体和业务逻辑 代码
FluentData,它是一个轻量级框架,关注性能和易用性. 下载地址:FlunenData.Model 利用T4模板,[MultipleOutputHelper.ttinclude]批量生成多文件 ...
- Spring JDBC Framework详解——批量JDBC操作、ORM映射
转自:https://blog.csdn.net/yuyulover/article/details/5826948 一.spring JDBC 概述 Spring 提供了一个强有力的模板类JdbcT ...
随机推荐
- SQL Server 2008 r2 中 SQL语句提示“对象名无效”,但可执行
[问题描述]在使用 SQL Server 2008 r2 时,有时在完成SQL书写后,会提示“对象名无效”,而SQL语句可正常执行. [原因]缓存相关. [解决方法]ctrl+shift+R 刷新下, ...
- C++面试中string类的一种正确简明的写法
本文首发于酷壳网 http://coolshell.cn/articles/10478.html 先说说程序员(应届生)面试的一般过程,一轮面试(面对一到两个面试官)一般是四.五十分钟,面试官会问两三 ...
- win8 vs2010 openni2 配置
打开一个新项目或者已存在的项目用以使用 OpenNI 在Visual Studio 菜单中, 打开项目菜单,选择项目属性. 在C/C++ 选项卡中, 在"常规" 下, 选择 &q ...
- 如何用Tacker将NFV带入OpenStack?
最初社区里很多人争论过NFV是否属于OpenStack,而后来可以确定的是OpenStack的确占据了NFV会话中的很大一部分,并且形象地反映在了下面的ETSI MANO概念架构图中,OpenStac ...
- Laravel 学习笔记 —— 神奇的服务容器 [转]
容器,字面上理解就是装东西的东西.常见的变量.对象属性等都可以算是容器.一个容器能够装什么,全部取决于你对该容器的定义.当然,有这样一种容器,它存放的不是文本.数值,而是对象.对象的描述(类.接口)或 ...
- iOS—如何申请苹果公司开发者账号流程详细图文介绍(包括邓白氏编码的申请方法详细介绍)
我们要申请开发者账号,首先就需要先注册一个苹果的apple id,然后再这个账号的基础上去继续,这个相信大家都知道 这是申请appleid的地址:https://appleid.apple.com/a ...
- LoopbackJS 生成对应 Oracle 视图的model
StrongLoop Arc 工具中的discover model 目前只能discover 表, Oracle数据库中的视图经测试并不能显示在列表中. 无奈之下,暂时只能采取替代方案. 解决方法: ...
- 删除从第i个位置开始,长度为len的子串
/*字符串采用带头结点的链表存储,设计算法函数void delstring(linkstring s, int i,int len)在字符串s中删除从第i个位置开始,长度为len的子串.*//**** ...
- sql连着function使用
create function fun002(@thename varchar()) returns int as begin declare @count int select @count=cou ...
- 轮播神器swiper插件
Swiper中文网:http://www.swiper.com.cn/ Swiper- 是免费的,最现代化的移动触摸滑块硬件加速的转换和惊人的天然行为.它的目的是在移动网站,移动网络应用和移动本地/混 ...