WTM的項目中EFCore如何適配人大金倉資料庫

来源:https://www.cnblogs.com/wdw984/p/18289632
-Advertisement-
Play Games

一、WTM是什麼 WalkingTec.Mvvm框架(簡稱WTM)最早開發與2013年,基於Asp.net MVC3 和 最早的Entity Framework, 當初主要是為瞭解決公司內部開發效率低,代碼風格不統一的問題。2017年9月,將代碼移植到了.Net Core上,併進行了深度優化和重構, ...


一、WTM是什麼

WalkingTec.Mvvm框架(簡稱WTM)最早開發與2013年,基於Asp.net MVC3 和 最早的Entity Framework, 當初主要是為瞭解決公司內部開發效率低,代碼風格不統一的問題。
2017年9月,將代碼移植到了.Net Core上,併進行了深度優化和重構,推出了基於Asp.net Core和EF Core的全新框架,新框架在架構,穩定性,速度上都有長足進步,真正成為一款高效開發的利器。
經歷了四年間數十個項目的考驗,框架逐步的完善,推出了四個主要版本。
WTM框架設計的核心理念就是”盡一切可能提高開發效率“。
WTM框架把常規編碼結構化,重覆編碼自動化,它不僅是一個框架,它是強有力的生產力工具!
在不分離的模式下,它連通了前臺UI和後臺代碼。你不需要前後臺分離,不需要兩個人配合,減少成本,縮短工期。
在前後端分離的模式下,同樣可以使用代碼生成器同時生成前臺和後臺的代碼,極大的降低了前後端人員的溝通成本,從本質上提升了開發效率,讓“分離”不再複雜和昂貴。
框架特點:
一鍵生成WTM項目
一鍵生成增刪改查,導入導出,批量操作代碼
支持一對多,多對多關聯模型的識別和代碼生成
支持React+AntD,Vue+Element,LayUI,Blazor等多種前端模式
支持sqlserver,mysql,pgsql,sqlite,Oracle等多種資料庫
封裝了Layui,AntD,Element的大部分控制項,編寫前臺更加簡便
提供了很多基類,封裝了絕大部分後臺常用操作
提供了用戶,角色,用戶組,菜單,日誌等常用模塊
支持數據許可權的開發和配置
支持讀寫分離和資料庫分庫

開源地址:
(GitHub) https://github.com/WalkingTec/WalkingTec.Mvvm
(Gitee) https://gitee.com/liuliang-wtm/WTM

二、人大金倉是什麼
人大金倉資料庫管理系統[簡稱:KingbaseES]是北京人大金倉信息技術股份有限公司[簡稱人大金倉]的核心產品,具有大型通用、"三高"(高可靠、高性能、高安全)、"三易"(易管理、易使用、易擴展)、運行穩定等特點,是唯一入選國家自主創新產品目錄的資料庫產品,也是國家級、省部級實際項目中應用最廣泛的國產資料庫產品。
人大金倉資料庫管理系統 KingbaseES(KES) 是面向全行業、全客戶關鍵應用的企業級大型通用資料庫管理系統,適用於聯機事務處理、查詢密集型數據倉庫、要求苛刻的互聯網應用等場景,提供全部應用開發及系統管理功能,提供性能增強特性,可支持主備集群、讀寫分離集群、多活共用存儲集群等全集群架構,具有高性能、高安全、高可用、易使用、易管理、易維護的特點,支持所有國內外主流CPU、操作系統與雲平臺部署。
下載試用地址:
https://www.kingbase.com.cn/xzzx/index.htm
可在下載頁面申請開發試用授權文件,授權時間365天。
安裝過程比較簡單,唯一需要註意的就是在安裝過程中可以選擇資料庫相容類型,這裡選擇的是UTF8字元集,相容MySql,大小寫不敏感。

 

三、遷移註意事項

項目用的是.NET6框架,在項目里引用(或者NuGet安裝)人大金倉官方的EFCore的Kdbndp驅動Kdbndp.EntityFrameworkCore6.KingbaseES。

1、工作流使用的資料庫所屬模式手動創建

WTM集成了Elsa的工作流,在遷移的過程中需要把Elsa所需要的幾個表遷移到特定的模式下麵,否則運行會提示找不到Elsa.xxxx的錯誤提示;

模式右鍵-->新建-->Elsa,然後把所需要的這幾個表遷移到它下麵。

2、欄位類型轉換

絕大部分的Mysql欄位可以無縫遷移到人大金倉,對於mysql的bool類型的欄位需要特別關註一下,會遷移成bit或者int類型,需要手動調整成人大金倉的bool類型;

mysql的datetime類型,遷移到人大金倉後對應的類型是timestamp。這個需要在DataContext的OnConfiguring中指定一下參數,否則會報以下錯誤:

System.InvalidCastException: Cannot write DateTime with Kind=Local to PostgreSQL type 'timestamp with time zone', only UTC is supported. Note that it's not possible to mix DateTimes with different Kinds in an array/range. See the Npgsql.EnableLegacyTimestampBehavior AppContext switch to enable legacy behavior.

具體參考:https://www.npgsql.org/doc/types/datetime.html#timestamps-and-timezones

protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
		{
			if (DBType == DBTypeEnum.PgSql)
			{
				AppContext.SetSwitch("Npgsql.EnableLegacyTimestampBehavior", true);
				AppContext.SetSwitch("Npgsql.DisableDateTimeInfinityConversions", true);
			}
			base.OnConfiguring(optionsBuilder);
		}

2、自增欄位實現

在mysql、sqlserver等資料庫中,只要把欄位設置為int,然後打開自增選項後,欄位就會實現自增功能。在人大金倉中,預設沒有這種欄位類型,官網中稱這種為序數類型,類似於Oracle的SEQUENCE:

smallserial、serial 和 bigserial類型不是真正的類型, 它們只是為了創建唯一標識符列而存在的方便符號(類似其它一些資料庫中支持的 AUTO_INCREMENT 屬性)。 這是 KingbaseES 特有的創建一個自增列的方法。

因為 smallserial、serial 和 bigserial 是用序列實現的,所以即使沒有刪除過行,在出現在列中的序列值可能有“空洞”或者間隙。如果一個從序列中分配的值被用在一行中,即使該行最終沒有被成功地插入到表中,該值也被“用掉”了。例如,當插入事務回滾時就會發生這種情況。更多信息參見序列操作函數中的 nextval()。

在人大金倉中需要通過序列類型實現欄位自增的方式,需要我們在資料庫的Public模式下的序列中,創建一個序列(這裡設置的最大值為bigint的最大值附近,具體可自己決定):

 

隨後,在需要自增的欄位,給它的預設值設置為 nextval('USER_SEQUENCE'::regclass)  ,這樣在每次insert數據的時候,這個欄位會自動從序列中獲取最新的值來填充(不需要代碼中進行賦值)。

至此就基本完成了mysql到人大金倉的資料庫遷移。


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

-Advertisement-
Play Games
更多相關文章
  • 前言 上一篇文章香橙派5plus上跑雲手機方案一 redroid(帶硬體加速)中說了怎麼運行redroid,這篇補一下怎麼修改參數編譯內核。 補充 上篇文章有個內容需要補充一下:更新完內核需要用下麵的命令防止內核被apt更新,不然後面使用apt update又回到官方的內核(註意版本號,當前是100 ...
  • 技術債可能來源於多種原因,比如時間壓力、資源限制、技術選型不當等。它可以表現為代碼中的臨時性修補、未能徹底解決的設計問題、缺乏文檔或測試覆蓋等。雖然技術債可以幫助快速推進項目進度,但長期來看,它會增加軟體維護的成本和風險,降低系統的穩定性和可維護性。 ...
  • 大模型技術的發展和應用,預示著更加智能化、個性化未來的到來。如果將大模型比喻為正在疾馳的科技列車,語料便是珍貴的“燃料”。本次世界人工智慧大會期間,合合信息為大模型打造的“加速器”解決方案備受關註。 在大模型訓練的上游階段,“加速器”中的文檔解析引擎將助力大模型突破在書籍、論文、研報等文檔中的版面解 ...
  • 大家好,我是碼農先森。 回想起以前用模版渲染數據的歲月,那時都沒有 API 介面開發的概念。PHP 服務端和前端 HTML、CSS、JS 代碼混合式開發,也不分前端、後端程式員,大家都是全乾工程師。隨著前後端分離、移動端開發的興起,用後端渲染數據的開發方式效率低下,已經不能滿足業務對需求快速上線的要 ...
  • ★ JWT基本概念 JWT(JSON Web Token)是一種用於在網路應用之間傳遞信息的安全方式。它是一種基於 JSON 的開放標準(RFC 7519),用於在網路應用之間安全地傳輸聲明。JWT 通常用於身份驗證和授權,以及在分散式系統中傳遞聲明。 ★ JWT組成部分 JWT 由三部分組成:頭部 ...
  • 什麼是監視器(Monitor)? 在Java中,監視器(Monitor)是用來實現線程同步的一種機制。每個Java對象都有一個與之關聯的監視器,線程可以通過synchronized關鍵字來獲取和釋放對象的監視器。監視器的主要作用是確保在同一時刻只有一個線程可以執行同步塊或同步方法,從而實現線程的互斥 ...
  • ★ 背景說明 在Django REST framework (DRF) 前後端分離項目中,解決CSRF問題通常有以下幾種方法: 1. 禁用CSRF驗證,但這會降低安全性。(不推薦) 2. 使用csrftoken cookie 3. 在前端每次 POST、PUT 或 DELETE 請求前先發起一個GE ...
  • 數字簽名作為PDF文檔中的重要安全機制,不僅能夠驗證文件的來源,還能確保文件內容在傳輸過程中未被篡改。然而,如何正確驗證PDF文件的數字簽名,是確保文件完整性和可信度的關鍵。本文將詳細介紹如何使用免費.NET控制項通過C#驗證PDF簽名的有效性以及驗證PDF文檔是否被修改。 C# 驗證PDF數字簽名有 ...
一周排行
    -Advertisement-
    Play Games
  • 通過WPF的按鈕、文本輸入框實現了一個簡單的SpinBox數字輸入用戶組件並可以通過數據綁定數值和步長。本文中介紹了通過Xaml代碼實現自定義組件的佈局,依賴屬性的定義和使用等知識點。 ...
  • 以前,我看到一個朋友在對一個系統做初始化的時候,通過一組魔幻般的按鍵,調出來一個隱藏的系統設置界面,這個界面在常規的菜單或者工具欄是看不到的,因為它是一個後臺設置的關鍵界面,不公開,同時避免常規用戶的誤操作,它是作為一個超級管理員的入口功能,這個是很不錯的思路。其實Winform做這樣的處理也是很容... ...
  • 一:背景 1. 講故事 前些天有位朋友找到我,說他的程式每次關閉時就會自動崩潰,一直找不到原因讓我幫忙看一下怎麼回事,這位朋友應該是第二次找我了,分析了下 dump 還是挺經典的,拿出來給大家分享一下吧。 二:WinDbg 分析 1. 為什麼會崩潰 找崩潰原因比較簡單,用 !analyze -v 命 ...
  • 在一些報表模塊中,需要我們根據用戶操作的名稱,來動態根據人員姓名,更新報表的簽名圖片,也就是電子手寫簽名效果,本篇隨筆介紹一下使用FastReport報表動態更新人員簽名圖片。 ...
  • 最新內容優先發佈於個人博客:小虎技術分享站,隨後逐步搬運到博客園。 創作不易,如果覺得有用請在Github上為博主點亮一顆小星星吧! 博主開始學習編程於11年前,年少時還只會使用cin 和cout ,給單片機點點燈。那時候,類似async/await 和future/promise 模型的認知還不是 ...
  • 之前在阿裡雲ECS 99元/年的活動實例上搭建了一個測試用的MINIO服務,以前都是直接當基礎設施來使用的,這次準備自己學一下S3相容API相關的對象存儲開發,因此有了這個小工具。目前僅包含上傳功能,後續計劃開發一個類似圖床的對象存儲應用。 ...
  • 目錄簡介快速入門安裝 NuGet 包實體類User資料庫類DbFactory增刪改查InsertSelectUpdateDelete總結 簡介 NPoco 是 PetaPoco 的一個分支,具有一些額外的功能,截至現在 github 星數 839。NPoco 中文資料沒多少,我是被博客園群友推薦的, ...
  • 前言 前面使用 Admin.Core 的代碼生成器生成了通用代碼生成器的基礎模塊 分組,模板,項目,項目模型,項目欄位的基礎功能,本篇繼續完善,實現最核心的模板生成功能,並提供生成預覽及代碼文件壓縮下載 準備 首先清楚幾個模塊的關係,如何使用,簡單畫一個流程圖 前面完成了基礎的模板組,模板管理,項目 ...
  • 假設需要實現一個圖標和文本結合的按鈕 ,普通做法是 直接重寫該按鈕的模板; 如果想作為通用的呢? 兩種做法: 附加屬性 自定義控制項 推薦使用附加屬性的形式 第一種:附加屬性 創建Button的附加屬性 ButtonExtensions 1 public static class ButtonExte ...
  • 在C#中,委托是一種引用類型的數據類型,允許我們封裝方法的引用。通過使用委托,我們可以將方法作為參數傳遞給其他方法,或者將多個方法組合在一起,從而實現更靈活的編程模式。委托類似於函數指針,但提供了類型安全和垃圾回收等現代語言特性。 基本概念 定義委托 定義委托需要指定它所代表的方法的原型,包括返回類 ...