网站首页 > 数据库 / 正文
最近用EF连接oracle,采用dbfirst 的model first 模式,直接用oracle 表生产edmx文件的方式来实现增删改查,后来需要切换oracle的用户,就导致无法切换用户数据,这是微软的ef框架的陷阱,造成这个问题的原因是sqlserver 的schema 和oracle 的用户不是一套东西,只是形式上有点像,所以,ef连接oracle 不能使用model first模式,应该使用code first,
下面是code irst 的一些更改:
连接字符串跟edmx方式的字符串不一样了,如下:
然后需要动态获取oracle的用户名:这是我从博客园上摘抄的如下:
/// <summary>
/// 通过数据库连接名称获取模式名称(Oracle用)
/// </summary>
/// <param name="conName"></param>
/// <returns></returns>
internal static string GetSchemaByConName(string conName)
{
if (string.IsNullOrEmpty(conName)) throw new ArgumentNullException(nameof(conName));
var c = ConfigurationManager.ConnectionStrings[conName];
if (c == null)
throw new InvalidOperationException("Db Connection Not Found :" + conName);
if (string.IsNullOrEmpty(c.ConnectionString))
throw new Exception(#34;ConnectionString {conName} is empty!");
//获取User Id
var sp = c.ConnectionString.Split(';');
var u = sp.Where(x => !string.IsNullOrEmpty(x) && x.Contains("=")).FirstOrDefault(y => y.Trim().ToLower().StartsWith("user"));
if (u == null)
throw new Exception(#34;ConnectionString {conName} is invalid !");
sp = u.Split('=');
return sp[1].Trim().ToUpper();
}
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
//模式调整
modelBuilder.HasDefaultSchema(GetSchemaByConName(ConnectionName));
}
然后就是 dataannotations 方式给class 添加table映射,还有主键的dataannotations定义
[Table()] 不需要加schema
[Key,DatabaseGenerated(DatabaseGeneratedOption.None)]
Tags:oracle 左连接
猜你喜欢
- 2024-11-26 开源BI工具Superset数据库连接介绍
- 2024-11-26 Windows server 2016 安装oracle的教程图解
- 2024-11-26 用strace动态查看新建TCP连接服务端的socket参数选项
- 2024-11-26 python-oracledb——利用python连接Oracle数据库的好用方法
- 2024-11-26 一次搞定各种数据库 SQL 执行计划 | 原力计划
- 2024-11-26 BI工具入门:如何做关系数据源的连接?
- 2024-11-26 Oracle基本select语句学习总结
- 2024-11-26 常用SQL系列之(三):记录叠加、匹配、外连接及笛卡尔等
- 2024-11-26 如何使用Python连接MySQL数据库?
- 2024-11-26 第1章 Oracle 第一天