Mego开发文档 - 复杂保存操作
复杂保存操作
Mego框架还提供了更强大的数据更新API,以简化开发工作,同时也保证的性能。
指定属性添加数据
本列中指定插入一个数据对象,并且只会插入三列数据,最后两个属性是以表达式的形式插入。
using (var db = new OrderManageEntities())
{
db.Customers.Add(a => new Customer()
{
Id = a.Id,
Name = a.Name + "a",
Address1 = a.Address1 + a.Address2
}, new Customer()
{
Id = 10000,
Name = "sdfdsf",
Address1 = "a",
Address2 = "b"
});
db.Executor.Execute();
}
指定属性更改数据
本例中指定更新一个数据对象的Name和Address1属性,并且Address1的值是计算出来的。
using (var db = new OrderManageEntities())
{
var data = db.Customers.First();
data.Address1 = "aaaa";
data.Address2 = "bbbb";
db.Customers.Update(a => new Customer()
{
Name = a.Name,
Address1 = a.Address2 + "-" + a.Address1
}, data);
db.Executor.Execute();
}
条件删除数据
本例中指定删除满足Number等于1的所有Warehouse。
using (var db = new OrderManageEntities())
{
var operate = db.Warehouses.Remove(a => a.Number == 1);
db.Executor.Execute(operate);
}
联合添加数据
本例中将从Product对应的数据表中查询出结果并插入到Customer对应的数据表中。
using (var db = new OrderManageEntities())
{
var operate = db.Customers.Add(from a in db.Products
where a.Id > 5
select new Customer()
{
Id = a.Id + 10000,
Name = a.Name,
Code = a.Name,
Address1 = a.Code
});
db.Executor.Execute(operate);
}
联合更新数据
本例中将从Customer及Product中查找主键相同的数据并更新指定字段。
using (var db = new OrderManageEntities())
{
var operate = db.Customers.Update(from b in db.Customers
join a in db.Products on b.Id equals a.Id
where a.Id > 100
select new Customer()
{
Name = a.Name,
Code = a.Name,
Address1 = a.Code,
});
db.Executor.Execute(operate);
}
联合删除数据
using (var db = new OrderManageEntities())
{
var operate = db.Warehouses.Remove(from a in db.Warehouses
from b in db.Customers
where a.Id == b.Id && a.Number > 100
select a);
db.Executor.Execute(operate);
}
Mego开发文档 - 复杂保存操作的更多相关文章
- Mego开发文档 - 基本保存操作
基本保存操作 在Mego中没有更改跟踪,也就是说所有的新增.更新及删除都需要开发者自行判断.Mego会最为实际的将各个数据操作提交给数据库并执行. 添加数据 using (var db = new O ...
- Mego开发文档 - 索引
Mego 开发文档 Mego 快速概述 主要特性 获取Mego 使用流程 模型 查询 保存数据 入门 Mego 快速开始 创建项目 安装Nuget包 创建连接字符串 创建模型及数据上下文(添加引用) ...
- Mego开发文档 - 保存关系数据
保存关系数据 由于没有对象的更改跟踪,因此关系的操作需要开发者明确指定,在成功执行后Mego会影响到相应的关系属性中. 添加关系 在以下示例中如果成功执行则source的Customer属性会变为ta ...
- Mego开发文档 - 快速概述
Mego 快速概述 Mego 是一款轻量级,可扩展和跨平台的数据访问技术. Mego 是一个对象关系映射器(O / RM),它使.NET开发人员能够使用.NET对象处理数据库.它消除了开发人员通常需要 ...
- Mego开发文档 - 快速开始
Mego 快速开始 我们将创建一个简单的数据新增及查询来演示 Mego 的使用过程.演示中都是使用 Visual Studio 2017 作为开发工具,SQL Server 2012 作为数据库. 创 ...
- Mego开发文档 - 处理并发冲突
处理并发冲突 数据库并发是指多个进程或用户同时访问或更改数据库中的相同数据的情况.并发控制是指用于确保存在并发更改时数据一致性的特定机制. Mego实现了乐观并发控制,这意味着它可以让多个进程或用户独 ...
- Mego开发文档 - 事务
事务 事务允许以原子方式处理多个数据库操作.如果事务已提交,则所有操作都已成功应用于数据库.如果事务回滚,则没有任何操作应用于数据库. 默认行为 默认情况下,如果数据库提供程序支持事务,则单次的提交操 ...
- Mego开发文档 - 从EF6/EFCore迁移到Mego
从EF6/EFCore迁移到Mego框架 如果您有EntityFragmework6或EntityFragmeworkCore的开发经验,在首次接触Mego框架时会发现这两个框架非常相似,本文将帮忙您 ...
- Mego开发文档 - 数据注释建模
数据注释建模 Mego框架使用一组约定来基于CLR类来构建模型.您可以指定其他配置来补充或覆盖通过约定发现的内容. 在 Mego 中所有的数据对象必须要有主键.这里需要声明与EF不同的是框架只支持数据 ...
随机推荐
- To Fill or Not to Fill (贪心)
转自:https://www.cnblogs.com/XBWer/p/3866486.html With highways available, driving a car from Hangzhou ...
- c++cout执行顺序之一个不容易注意到的一点
二话不说,先看一个例子 #include <iostream> using namespace std; int main() { ]={,,,,,,,,,}; int *p=a; int ...
- 8086的分段寻址技术学习总结(Segmented Addressing)
计算机最小粒度的数据单位是bit,但是为每个bit都分配地址不仅浪费资源,同时存取效率低.因此转而用8bits(也就是1个字节,1byte)来占用一个地址. 那么16位的地址线能够访问的地址空间大小为 ...
- Linux/Unix 资源
Linux/Unix笔记本 初窥Linux 之 我最常用的20条命令 Linux Shell脚本教程
- prompt 方法显示输入对话框
prompt 方法显示输入对话框 原理: prompt() 方法用于与用户交互,提示用户输入信息的对话框. prompt(str1,str2);此方法包含两个属性: str1:用于提示用户输入的信息. ...
- Geth 控制台使用及 Web3.js 使用实战
在开发以太坊去中心化应用,免不了和以太坊进行交互,那就离不开Web3.Geth 控制台(REPL)实现了所有的web3 API及Admin API,使用好 Geth 就是必修课.结合Geth命令用法阅 ...
- 面向对象写的简单的colors rain
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> < ...
- 如何使用svn命令行更新想要的目录?
内容来自网络. 一 某些原因想在svn co的时候排除某些目录,可以绕个圈子,分三步来完成:co外层目录:svn checkout --depth empty URL[URL[LOCATION]完成之 ...
- STL --> deque双向队列
deque简介 deque是双向开口的连续性存储空间.虽说是连续性存储空间,但这种连续性只是表面上的,实际上它的内存是动态分配的,它在堆上分配了一块一块的动态储存区,每一块动态存储去本身是连续的,de ...
- Spring Boot with Spring-Data-JPA学习案例
0x01 什么是Spring Boot? Spring Boot是用来简化Spring应用初始搭建以及开发过程的全新框架,被认为是Spring MVC的"接班人",和微服务紧密联系 ...