ABP適配Oracle全過程

来源:https://www.cnblogs.com/yuluowuhun/archive/2018/12/05/10063084.html
-Advertisement-
Play Games

一、背景   ABP的各類文檔在網路上已經非常完善了,唯獨缺少與oralce相關的資料,ABP官網也未給出一個較好的Oracle解決方案。正好最近在學習ABP相關知識,對ABP源碼結構稍算熟悉,花了些時間進行ABP適配Oracle。 二、準備    "ABP官 ...


一、背景

  ABP的各類文檔在網路上已經非常完善了,唯獨缺少與oralce相關的資料,ABP官網也未給出一個較好的Oracle解決方案。正好最近在學習ABP相關知識,對ABP源碼結構稍算熟悉,花了些時間進行ABP適配Oracle。

二、準備

  ABP官網 下載ABP模板(選擇.netframework MVC 版本)

  github 下載源碼

  資料庫:Oracle 11g

  開發工具:vs2017

三、鏈接Oracle

  前期工作都準備好後,開搞開搞!!

1、Oracle EF 驅動  

  分別在web和EntityFramework添加oracle ef 引用(install-package Oracle.ManagedDataAccess.EntityFramework),直接安裝該包會自動添加ODP.Net引用

2、鏈接oracle

  oralce依賴添加好後,我們會發現web.config自動添加了oracle連接配置,將我們需要鏈接的資料庫加到上面去(ps:oracle的鏈接字元必須為完整) 配置好資料庫鏈接後,直接運行程式試試看,出現瞭如下錯誤


3、數據遷移

  既然使用了EF,數據遷移必然少不了,通過執行Add-Migration和update-database指令,查看oracle資料庫里生成出來的數據表都是區分大小寫(註入AbpModules)。通常而言,我們在plsql建數據表,oracle會自動建表名和欄位名轉為大寫
顯然code-first生成出來的數據表不是我們想要的,那我們要怎麼修改呢?此時,就需要引入源碼,進行源碼改造。

四、源碼改造

1、重寫表名和欄位名

  將需要的ABP源碼引入,並修改對應依賴


  找到ABP.Zero.Common類庫,改寫實體,通過特性將所有映射到資料庫的實體名和屬性名改為大寫。


  修改完後,通過數據遷移將數據表生成到資料庫中,得到如下數據表

2、源碼改造

  僅僅只是重寫表名和欄位名遠遠達不到我們實際的應用需求,oracle 11g 主鍵無法自增,ABP預設主鍵都是int 自增。這導致無法使用ABP預設的許可權管理模塊,那麼我們需要將所有表的主鍵都修改為string,然後只需要根據程式報錯提示進行修改。(ps:主鍵此時非自增類型,需要賦值)

五、End

  源碼改造完後,重新進行數據遷移。運行程式,正常顯示登錄界面,但無法登錄,這是因為數據遷移時,部分種子數據無法正常寫入到資料庫,暫時手工寫入基礎數據。輸入admin/123qwe後,正常顯示主界面,角色管理、租戶管理等菜單未顯示,跟蹤後臺發現是許可權角色無法取到值,後續待完善。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近在做個微信公眾號的項目,需要將入口放置在公眾號二級菜單內,通過點擊該菜單鏈接後進入到該項目中去,進入到項目後程式會自動通過微信公眾號的API完成用戶的OpenId獲取。需求很簡單,實現起來也不複雜,於是在一番折騰後需求實現了。為此,寫下此文僅為初次接觸的朋友提供個小小的幫助。 ...
  • DataGridView控制項中的各種事件都無法直接響應Cell中內容的變化,包括KeyPress等事件,可以採用下麵方法 註:此方法無法響應Cell中的回車鍵 ...
  • 路由設置 ...
  • 前言: 自從.net core問世之後,就一直想瞭解。但是由於比較懶惰只是斷斷續續瞭解一點。近段時間工作不是太忙碌,所以偷閑寫下自己學習過程。慢慢瞭解.net core 等這些基礎方面學會之後再用.net core寫一個項目,前期文章都是為之後的項目做準備。同時也希望這些基礎文章能幫助更多的想入手 ...
  • IIS配置問題,解決方法: 1. 首先添加MIME類型 擴展名“.svc”,MIME類型 “application/octet-stream” 2、處理程式映射--添加托管處理程式 請求路徑 “.svc” 類型 “System.ServiceModel.Activation.HttpHandler  ...
  • 12月4日,微軟2019開發者大會中發佈了一系列的重磅消息,包含了軟硬體和開源社區的各種好消息是鋪天蓋地,作為一名普通的開發者,我第一時間下載了 .NET Core 2.2 的源碼,針對發佈說明逐條瀏覽,並截取了部分常用的功能進行嘗試,下麵就與大家分享。 ...
  • Net Core 2.2發佈了,關於3.0 Preview1和Windows桌面的詳細信息,官方博客也給出了更新內容。 ...
  • Net Core 2.2發佈了,關於EF Core2.2官方也給出了更新內容,本篇為官方博客翻譯。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...