当前位置: 首页 > article >正文

.Net使用EF Core框架如何连接Oracle

目录

一、Nutget包添加

二、 配置文件

三、创建实体类

四、创建数据库上下文类

五、将数据库上下文服务注册到容器

六、测试数据库数据

(1)编写PeopleController

(2)编写People页面


一、Nutget包添加

一定要安装Oracle.MangedDataAccess,他是Oracle的驱动程序。如果是使EntityFrameworkCore框架操作Oracle,则还需要引入Oracle.EntityFrameWorkCore

二、 配置文件

在appsetting.json文件中写好数据的连接信息,这里我本来使用的是Data source=tns别名,但是报错了,后面我也看了tnsnames.ora中的信息,tns别名也没有错。但是一直报错,所以我只能将这个连接信息全部写全了。

{
  "ConnectionStrings": {
    "oracleConnect": "User Id=用户名;Password=用户密码;Data Source=(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=127.0.0.1)(PORT=1521))(CONNECT_DATA=(SERVICE_NAME=服务名称)))"
  },
  "Logging": {
    "LogLevel": {
      "Default": "Information",
      "Microsoft.AspNetCore": "Warning"
    }
  },
  "AllowedHosts": "*"
}

三、创建实体类

因为Oracle默认的话不管是大写还是小写,最后都会转换成大写,所以如果实体类的名字如果和表明不一致的话(大写小写Oracle是有区别的),会报错!

所以使用了[Table]属性来映射对应的表。

包括属性名也是如此,使用了[Column]来映射对应的属性名

using System.ComponentModel.DataAnnotations.Schema;

namespace OracleConnectTest.Models
{
    [Table("PEOPLE")]
    public class People
    {
        //oracle默认全部是大写
        [Column("ID")]
        public int id { get; set; }
        [Column("NAME")]
        public string name { get; set; }
    }
}

四、创建数据库上下文类

创建一个Data文件夹,将该类(数据库上下文类)放入其中(个人习惯!)

using Microsoft.EntityFrameworkCore;
using OracleConnectTest.Models;
using System.ComponentModel.DataAnnotations.Schema;

namespace OracleConnectTest.Data
{
    public class OracleConnectTestContext : DbContext
    {
        public OracleConnectTestContext(DbContextOptions options) : base(options)
        {
        }
      
        public DbSet<People> peoples { get; set; }
    }
}

五、将数据库上下文服务注册到容器

Program.cs

using Microsoft.EntityFrameworkCore;
using OracleConnectTest.Data;

var builder = WebApplication.CreateBuilder(args);

//依赖项注入
builder.Services.AddDbContext<OracleConnectTestContext>(options =>
         options.UseOracle(builder.Configuration.GetConnectionString("oracleConnect")));

六、测试数据库数据

(1)编写PeopleController

using Microsoft.AspNetCore.Mvc;
using OracleConnectTest.Data;

namespace OracleConnectTest.Controllers
{
    public class PeopleController : Controller
    {
        private readonly OracleConnectTestContext _context;

        public PeopleController(OracleConnectTestContext context)
        {
            _context = context;
        }

        public IActionResult Index()
        {
            var s=_context.peoples.ToList();
            return View(s);
        }
    }
}

(2)编写People页面

@*
    For more information on enabling MVC for empty projects, visit https://go.microsoft.com/fwlink/?LinkID=397860
*@
@{
}
@model List<OracleConnectTest.Models.People>;

@foreach(var item in Model){
    <p>@item.id</p>
    <p>@item.name</p>
    
}

 


http://www.kler.cn/a/542951.html

相关文章:

  • 民兵装备管理系统DW-S300|支持国产化、自主研发
  • 使用 Go 语言调用 SiliconFlow 语音生成 API 的脚本,用于将文本转换为 MP3 格式的语音文件。
  • 3.3 学习UVM中的uvm_driver 类分为几步?
  • 逆势而上,门店规模拓展的智慧攻略-中小企实战运营和营销工作室博客
  • 个人毕业设计--基于HarmonyOS的旅行助手APP的设计与实现(挖坑)
  • HalconDotNet 基础操作
  • JVM-Java虚拟机
  • 在postman中设置环境变量和全局变量以及五大常用响应体断言
  • 【C#零基础从入门到精通】(十四)——面向对象三大特征C#封装详解
  • 二叉树、平衡二叉树、B树与B+树的区别与应用
  • redis的数据结构介绍(string
  • 心脏滴血漏洞复现(CVE-2014-0160)
  • 备战蓝桥杯:双指针(滑动窗口)算法之逛花展
  • SpringBoot分布式开发依赖项中,除了myql、redis,都要哪些依赖项是需要本地安装软件并开启服务的?
  • 蓝桥杯---N字形变换(leetcode第6题)题解
  • IDEA中列举的是否是SpringBoot的依赖项的全部?在哪里能查到所有依赖项,如何开发自己的依赖项让别人使用
  • Django:构建高效Web应用的强大框架
  • Idea集成deepseek生成代码
  • ffmpeg -hwaccels
  • 用 TDD 构建 Rust 命令行搜索功能:以 minigrep 为例
  • 3D文档控件Aspose.3D实用教程: 在 Java 中创建 FBX 文件并无缝将圆柱体转换为网格
  • 企业数据集成案例:吉客云销售渠道到MySQL
  • 率失真理论(Rate-Distortion Theory)和信息瓶颈(Information Bottleneck, IB)
  • Flutter_学习记录_安装第三方包(演示安装 Intl 包)
  • 2025智能名片:AI驱动下的商务社交革命
  • 蓝桥杯C语言组:分治问题研究