Entity Framework Core链接Oracle的问题

最近使用 Entity Framework Core 来链接 Oracle 11g 数据库,发现很多 LINQ 语句使用起来都会有问题,查看日志输出发现是生成SQL语句无法被 11g 版本执行,好在Oracle官方已经给我们提供了解决方案。

配置日志输出

先说一下怎么配置 efcore 的日志输出,方便我们定位问题。

一般有两种方案,一是修改 appsetting.Developer.json 文件,将日志等级设为 Trace 输出全部调试日志,其中必然是包含着数据库操作日志的。

{
  "Logging": {
    "LogLevel": {
      "Default": "Trace",
      "Microsoft": "Trace",
      "Microsoft.Hosting.Lifetime": "Trace"
    }
  },
  "ConnectionStrings": {
    "Oracle": "Data Source=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=127.0.0.1)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=ORCL)));User Id=SCOTT;Password=123;"
  }
}

上述方案会打印所有的调试日志,包含很多无用的信息,如果只想看数据库操作,则可以单独在 DbContext 中进行配置,重载 OnConfiguring 方法即可

protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
          =>  optionsBuilder.LogTo(Console.WriteLine);

预设Oracle数据库版本

Oracle官方提供的 Entity Framework Core 扩展包在执行时,会将 LINQ 翻译成 12c 以上版本使用的语法,其中包含着很多新语法,比如 OFFSET , LIMIT , OUTER APPLY 等,这些新语法在 11g 及之前的版本都是无法执行的

解决方案是在注册 DbContext 时,就指定好版本为 11,那在使用时,LINQ 就可以被翻译成老版本语法

services.AddDbContext<AppDbContext>(
         x => x.UseOracle(
                Configuration.GetConnectionString("Oracle"),
                y => y.UseOracleSQLCompatibility("11")));

这时候再执行例如分页,取第一行操作时,就不会使用 OFFSETLIMIT,而是去使用 ROWNUM 来进行分页

发布时间:2021-09-16
其他阅读

管道技术——中间件的灵魂

在现代Web开发中,中间件技术使用越来越广泛,本文带大家了解中间件的基础,同时也是中间件的灵魂所在,管道技术。在C#中,依赖于委托,我们可以很容易就实现一个中间件管道。所以在阅读本文前,请确保你已经学会了什么是委托,包括但不限于Delegate,Action,Func。除此之外,本文还会使用到反射相关知识,请确保你已经学会了什么是反射。

查看原文

使用正则表达式来判断邮箱

在开发中,很多地方都需要用户输入邮箱,用户注册,登录需要邮箱,订阅消息需要邮箱,为了防止被恶意使用,一般都会使用正则表达式来判断输入是否符合邮箱规范

查看原文

静态文件防盗链的一种思路

在我们的系统中,总会有一些资源需要保护起来不被盗走,如果是动态接口可以通过验证权限来保护,静态资源大多需要对外开放,比较难以保护,本文就介绍保护静态文件资源一种思路——那就是使用 HTTP 中 Referer 头。

查看原文

Fetch发送请求

fetch 是 javascript 中一个新的 api,用于访问和控制 HTTP 的请求和响应等,不再需要使用传统的 XMLHttoRequest

查看原文

TypeScript中的数组操作

我们在编码时,总会用到数组/列表这种类型,用于在单个对象中存储多个内容。在 TypeScript 中,也已经内置了该类型,方便我们来使用。

查看原文