[大雾雾雾雾] 告别该死的 EFCore Fluent API (续)
朋友们好啊,
我是 .NET 打工人 玩双截棍的熊猫
刚才有个朋友问我 猫猫发生什么事了
我说 怎么回事?
给我发了一张截图

我一看!嗷!原来是zuo天有两个数据库,
一个四十多岁,一个三十多岁
它们说
有一个说我列名全大写 (全小写),EFCore生成列名区分大小写
猫猫你能不能帮帮我 ?
帮助治疗一下我全大写(全小写)
我说可以
我说你看 [大雾雾雾雾] 告别该死的 EFCore Fluent API
他说 你这也没用
我说 我这有用
这个是反射,.NET 是讲反射的,反射动态调用
2000 年发布的 .NET 都有反射特性的
他说要试试
我说可以
我一说
他 “啪!” 就站起来了,很快啊
然后上来就是一个 低性能
一个 不合理
一个 真辣鸡!

我全部防出去了
防出去以后自然是传统艺能宜点到为止,代码放在了截图里,没复制出来。我笑了一下,准备撤回。

因为这个时候按照传统艺能他已经输了,如果这代码发力,一段就把电脑性能吃满了(雾雾雾)。
他也承认我的类库有点意思,他不知道代码截图已经放到他脸上,他承认我先把代码截图发出来。
我撤回代码截图不打了,他突然袭击大量反射性能低来打我脸。

我没有大E啊,也没有闪。
“啪!”就使出一招 Riven.EntityFrameworkCore 打到他脸上
直接重写 Entity Framework Core 驱动默认实现,从源头解决大小问题。
目前扩展的 EF Core 数据库驱动
- PostgreSQL
- Oracle
- DevartOracle
基本用法
- 引入nuget包
Postgresql
dotnet cli
dotnet add package Riven.EntityFrameworkCore.PostgreSQLnuget package manager
Install-Package Riven.EntityFrameworkCore.PostgreSQL
Oracle
- dotnet cli
dotnet add package Riven.EntityFrameworkCore.Oracle - nuget package manager
Install-Package Riven.EntityFrameworkCore.PostgreSQL
- dotnet cli
DevartOracle
- dotnet cli
dotnet add package Riven.EntityFrameworkCore.DevartOracle - nuget package manager
Install-Package Riven.EntityFrameworkCore.DevartOracle
- dotnet cli
- 使用驱动
- PostgreSQL
builder.UseRivenPostgreSQL(
"database connection string"
);
// or
builder.UseRivenPostgreSQL(
"database connection string",
(options)=>
{
}
);
- Oracle
// Default SQLCompatibility V11
builder.UseRivenOracle(
"database connection string"
);
// or
builder.UseRivenOracle(
"database connection string",
(options)=>
{
// SQLCompatibility V12
//options.UseOracleSQLCompatibility(OracleSQLCompatibility.V12)
}
);
- Devart Oracle
var license = ""; // Devart license
builder.UseRivenDevartOracle(
"database connection string",
license
);
// or
builder.UseRivenDevartOracle(
"database connection string",
license,
(options)=>
{
}
);
与 E.EntityFrameworkCore.Extensions 相比,更底层 / 更原生 / 性能更佳
虽然暂时不支持 E.EntityFrameworkCore.Extensions 的一些功能,但我会往里加的
如果觉得好用的话请 收藏 转发 star fork 一把梭 源码仓库

Riven
玩双截棍的熊猫
EFCore
EF Core
EntityFramework
EntityFrameworkCore
[EF Core Oracle 列名大小写问题]
[EF Core Oracle column name case problem]
[EF Core PostgreSql 列名大小写问题]
[EF Core PostgreSql column name case problem]
[EFCore Oracle 列名大小写问题]
[EFCore Oracle column name case problem]
[EFCore PostgreSql 列名大小写问题]
[EFCore PostgreSql column name case problem]
[entity framework core Oracle 列名大小写问题]
[entity framework core Oracle column name case problem]
[entity framework core PostgreSql 列名大小写问题]
[entity framework core PostgreSql column name case problem]
[大雾雾雾雾] 告别该死的 EFCore Fluent API (续)的更多相关文章
- [大雾雾雾雾] 告别该死的 EFCore Fluent API
[EF Core Oracle 列名大小写问题] [EF Core Oracle column name case problem] [EF Core PostgreSql 列名大小写问题] [EF ...
- 微软跨平台ORM框架之EFCore — 约定与属性映射
EFCore中的约定简单来说就是规则,CodeFirst基于模型的约定来映射表结构.除此之外还有Fluent API.Data Annotations(数据注释) 可以帮助我们进一步配置模型. 按照这 ...
- .NetCore中EFCore的使用整理(二)-关联表查询
EF常用处理关联加载的方式有3中:延迟加载(Lazy Loading).贪婪加载 (Eager Loading)以及显示加载. 一.EF Core 1.1 1.当前的版本,还不支持延迟加载(Lazy ...
- EF6&EFCore 注册/使用实体类的正确姿势
首先回顾下EF中常规使用流程 1.新建实体类以及实体配置(data annotation或fluent api) [Table("Users")] public class Use ...
- 基于efcore的分表组件开源
ShardingCore ShardingCore 是一个支持efcore 2.x 3.x 5.x的一个对于数据库分表的一个简易扩展, 目前该库暂未支持分库(未来会支持),仅支持分表,该项目的理念是让 ...
- efcore分表下"完美"实现
ShardingCore 如何呈现"完美"分表 这篇文章是我针对efcore的分表的简单介绍,如果您有以下需求那么可以自己选择是否使用本框架,本框架将一直持续更新下去,并且免费开源 ...
- efcore分表分库原理解析
ShardingCore ShardingCore 易用.简单.高性能.普适性,是一款扩展针对efcore生态下的分表分库的扩展解决方案,支持efcore2+的所有版本,支持efcore2+的所有数据 ...
- EFCore 6.0入门看这篇就够了
前言 作为一直在dotNet行业耕耘的码农,这几年在大大小小项目中也涉及到了许多ORM框架,比如:EFCore,Dapper,NHibernate,SqlSugar等等,这些ORM都有各自的优缺点,大 ...
- EFCore 的 DbFirst 模式
1 前言 EF6 时代,可以通过界面操作,添加数据库实体. EF Core 需要通过 CLI 来进行该操作,具体请参考EF Core官方文档:反向工程. 2 前置条件 PMC 工具(仅限 Visual ...
随机推荐
- Anderson《空气动力学基础》5th读书笔记 第5记——推导二维机翼的空气动力学系数
机翼的受力分析图 我们知道,空气对一个物体产生的升力和阻力以及力矩源于作用在整个物体上的压力分布和剪切力分布,所以我们分析上图可知(取单位展长的机翼): 对于上表面: ...
- Django (学习第二部 ORM 模型层)
Django对数据库的操作 Django的 ORM 简介 ORM操作 (增删改查) ORM操作数据库的增删改查 ORM创建表关系 ORM中常用字段及参数 数据库的查询优化 ORM中如何开启事务 ORM ...
- Gerrit 服务搭建和升级详解(包括 H2 数据库迁移 MySQL 步骤)
1. 安装Gerrit-2.9.5版本(Ubuntu) Gerrit版本:Gerrit-2.9.5.war 操作系统:Ubuntu 16.04.3 JAVA环境:java version " ...
- TypeScript魔法堂:函数类型声明其实很复杂
前言 江湖有传"动态类型一时爽,代码重构火葬场",由于动态类型语言在开发时不受数据类型的约束,因此非常适合在项目原型阶段和初期进行快速迭代开发使用,这意味着项目未来将通过重写而非重 ...
- hello world .net core 微服务框架 Viper
1.Viper是什么? Viper 是.NET平台下的Anno微服务框架的一个示例项目.入门简单.安全.稳定.高可用.全平台可监控.底层通讯可以随意切换thrift grpc. 自带服务发现.调用链追 ...
- Linux 系统编程 学习:02-进程间通信1:Unix IPC(1)管道
Linux 系统编程 学习:02-进程间通信1:Unix IPC(1)管道 背景 上一讲我们介绍了创建子进程的方式.我们都知道,创建子进程是为了与父进程协作(或者是为了执行新的程序,参考 Linux ...
- Python彩蛋、字典、列表高级用法、元类、混入、迭代器、生成器、生成式、git
一.类与类的关系 关注公众号"轻松学编程"了解更多. is-a 继承 继承是指一个类(称为子类.子接口)继承另外一个类(称为父类.父接口)的功能, 并可以增加它自己的新功能的能力. ...
- Ideas and Tricks Part II
33.对于统计答案幂次的技巧 对于$x^k$,考虑其组合意义:将$k$个不同球放到$x$个不同的盒子里的方案数,直接维护不好维护,那么考虑枚举把这些球放到了哪些盒子里,最后乘上第二类斯特林数和对于的阶 ...
- 配置交换机基于接口划分VLAN(接入层设备作为网关)
组网图形 简介 划分VLAN的方式有:基于接口.基于MAC地址.基于IP子网.基于协议.基于策略(MAC地址.IP地址.接口).其中基于接口划分VLAN,是最简单,最常见的划分方式. 基于接口划分VL ...
- 11 幂等 Idempotence
11 幂等 Idempotence HTTP方法的幂等性是指一次和多次请求某一个资源应该具有同样的副作用.(注意是副作用) GET http://www.bank.com/account/123456 ...