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
  • 移動開發(一):使用.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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...